@shenghuabi/openai 1.2.1 → 1.2.4
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/chat/chat.d.ts +4 -1
- package/chat/message.define.d.ts +19 -6
- package/chat/util/get-custom-provider.d.ts +2 -2
- package/define/index.js +7 -2
- package/define/index.js.map +2 -2
- package/define/index.mjs +6 -2
- package/define/index.mjs.map +2 -2
- package/index.js +81 -14
- package/index.js.map +3 -3
- package/index.mjs +83 -15
- package/index.mjs.map +3 -3
- package/package.json +1 -1
package/chat/chat.d.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { Context, StreamOptions } from '@earendil-works/pi-ai';
|
|
2
2
|
import { ModelConfigInputType } from './util/get-custom-provider';
|
|
3
3
|
import type OpenAI from 'openai';
|
|
4
|
+
import { ChatMessageItemType } from './message.define';
|
|
4
5
|
import { Injector } from 'static-injector';
|
|
5
|
-
export declare function createChatStream(input: ModelConfigInputType): (context: Context,
|
|
6
|
+
export declare function createChatStream(input: ModelConfigInputType): (context: Omit<Context, "messages"> & {
|
|
7
|
+
messages: ChatMessageItemType[];
|
|
8
|
+
}, options?: StreamOptions, extra?: {
|
|
6
9
|
response_format?: OpenAI.Chat.Completions.ChatCompletionCreateParamsStreaming["response_format"];
|
|
7
10
|
injector?: Injector;
|
|
8
11
|
}) => AsyncGenerator<import("@earendil-works/pi-ai").AssistantMessageEvent, void, unknown>;
|
package/chat/message.define.d.ts
CHANGED
|
@@ -7,7 +7,6 @@ export type ChatCompletionContentPartStrType = v.InferOutput<typeof ChatCompleti
|
|
|
7
7
|
export declare const ChatCompletionContentPartImage: v.ObjectSchema<{
|
|
8
8
|
readonly image_url: v.ObjectSchema<{
|
|
9
9
|
readonly url: v.StringSchema<undefined>;
|
|
10
|
-
readonly detail: v.OptionalSchema<v.PicklistSchema<["auto", "low", "high"], undefined>, undefined>;
|
|
11
10
|
}, undefined>;
|
|
12
11
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
13
12
|
}, undefined>;
|
|
@@ -18,7 +17,6 @@ export declare const ChatCompletionContentPart: v.ArraySchema<v.UnionSchema<[v.O
|
|
|
18
17
|
}, undefined>, v.ObjectSchema<{
|
|
19
18
|
readonly image_url: v.ObjectSchema<{
|
|
20
19
|
readonly url: v.StringSchema<undefined>;
|
|
21
|
-
readonly detail: v.OptionalSchema<v.PicklistSchema<["auto", "low", "high"], undefined>, undefined>;
|
|
22
20
|
}, undefined>;
|
|
23
21
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
24
22
|
}, undefined>], undefined>, undefined>;
|
|
@@ -32,7 +30,6 @@ export declare const UserChatCompletionContent: v.ArraySchema<v.UnionSchema<[v.O
|
|
|
32
30
|
}, undefined>, v.ObjectSchema<{
|
|
33
31
|
readonly image_url: v.ObjectSchema<{
|
|
34
32
|
readonly url: v.StringSchema<undefined>;
|
|
35
|
-
readonly detail: v.OptionalSchema<v.PicklistSchema<["auto", "low", "high"], undefined>, undefined>;
|
|
36
33
|
}, undefined>;
|
|
37
34
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
38
35
|
}, undefined>], undefined>, undefined>;
|
|
@@ -57,7 +54,6 @@ export declare const UserChatMessage: v.ObjectSchema<{
|
|
|
57
54
|
}, undefined>, v.ObjectSchema<{
|
|
58
55
|
readonly image_url: v.ObjectSchema<{
|
|
59
56
|
readonly url: v.StringSchema<undefined>;
|
|
60
|
-
readonly detail: v.OptionalSchema<v.PicklistSchema<["auto", "low", "high"], undefined>, undefined>;
|
|
61
57
|
}, undefined>;
|
|
62
58
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
63
59
|
}, undefined>], undefined>, undefined>;
|
|
@@ -86,7 +82,25 @@ export declare const ChatMessageItemDefine: v.UnionSchema<[v.ObjectSchema<{
|
|
|
86
82
|
}, undefined>, v.ObjectSchema<{
|
|
87
83
|
readonly image_url: v.ObjectSchema<{
|
|
88
84
|
readonly url: v.StringSchema<undefined>;
|
|
89
|
-
|
|
85
|
+
}, undefined>;
|
|
86
|
+
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
87
|
+
}, undefined>], undefined>, undefined>;
|
|
88
|
+
}, undefined>, v.ObjectSchema<{
|
|
89
|
+
readonly role: v.OptionalSchema<v.LiteralSchema<"assistant", undefined>, "assistant">;
|
|
90
|
+
readonly content: v.ArraySchema<v.ObjectSchema<{
|
|
91
|
+
readonly text: v.StringSchema<undefined>;
|
|
92
|
+
readonly type: v.OptionalSchema<v.LiteralSchema<"text", undefined>, "text">;
|
|
93
|
+
}, undefined>, undefined>;
|
|
94
|
+
readonly thinkContent: v.OptionalSchema<v.StringSchema<undefined>, undefined>;
|
|
95
|
+
}, undefined>], undefined>;
|
|
96
|
+
export declare const ChatMessageCommonItemDefine: v.UnionSchema<[v.ObjectSchema<{
|
|
97
|
+
readonly role: v.OptionalSchema<v.LiteralSchema<"user", undefined>, "user">;
|
|
98
|
+
readonly content: v.ArraySchema<v.UnionSchema<[v.ObjectSchema<{
|
|
99
|
+
readonly text: v.StringSchema<undefined>;
|
|
100
|
+
readonly type: v.OptionalSchema<v.LiteralSchema<"text", undefined>, "text">;
|
|
101
|
+
}, undefined>, v.ObjectSchema<{
|
|
102
|
+
readonly image_url: v.ObjectSchema<{
|
|
103
|
+
readonly url: v.StringSchema<undefined>;
|
|
90
104
|
}, undefined>;
|
|
91
105
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
92
106
|
}, undefined>], undefined>, undefined>;
|
|
@@ -113,7 +127,6 @@ export declare const ChatMessageListDefine: v.ArraySchema<v.UnionSchema<[v.Objec
|
|
|
113
127
|
}, undefined>, v.ObjectSchema<{
|
|
114
128
|
readonly image_url: v.ObjectSchema<{
|
|
115
129
|
readonly url: v.StringSchema<undefined>;
|
|
116
|
-
readonly detail: v.OptionalSchema<v.PicklistSchema<["auto", "low", "high"], undefined>, undefined>;
|
|
117
130
|
}, undefined>;
|
|
118
131
|
readonly type: v.OptionalSchema<v.LiteralSchema<"image_url", undefined>, "image_url">;
|
|
119
132
|
}, undefined>], undefined>, undefined>;
|
|
@@ -4,8 +4,8 @@ export declare function getModelConfig(input: ModelConfigInputType): {
|
|
|
4
4
|
model: Model<any>;
|
|
5
5
|
config: ModelConfigOutputType;
|
|
6
6
|
};
|
|
7
|
-
export declare const ThinkingLevelSchema: v.SchemaWithPipe<readonly [v.PicklistSchema<["minimal", "low", "medium", "high", "xhigh"], undefined>, v.TitleAction<"
|
|
8
|
-
export declare const ModelThinkingLevelSchema: v.SchemaWithPipe<readonly [v.PicklistSchema<["off", "minimal", "low", "medium", "high", "xhigh"], undefined>, v.TitleAction<"off" | "
|
|
7
|
+
export declare const ThinkingLevelSchema: v.SchemaWithPipe<readonly [v.PicklistSchema<["minimal", "low", "medium", "high", "xhigh"], undefined>, v.TitleAction<"minimal" | "low" | "medium" | "high" | "xhigh", "思考等级">, v.DescriptionAction<"minimal" | "low" | "medium" | "high" | "xhigh", "模型思考的详细程度,从最小到最大">]>;
|
|
8
|
+
export declare const ModelThinkingLevelSchema: v.SchemaWithPipe<readonly [v.PicklistSchema<["off", "minimal", "low", "medium", "high", "xhigh"], undefined>, v.TitleAction<"off" | "minimal" | "low" | "medium" | "high" | "xhigh", "模型思考等级">, v.DescriptionAction<"off" | "minimal" | "low" | "medium" | "high" | "xhigh", "关闭或设置模型思考的详细程度">]>;
|
|
9
9
|
/** OpenAI Completions compatibility overrides */
|
|
10
10
|
export declare const OpenAICompletionsCompatSchema: v.SchemaWithPipe<readonly [v.OptionalSchema<v.ObjectSchema<{
|
|
11
11
|
readonly supportsStore: v.OptionalSchema<v.SchemaWithPipe<readonly [v.BooleanSchema<undefined>, v.TitleAction<boolean, "支持存储">, v.DescriptionAction<boolean, "是否支持服务端会话存储">]>, undefined>;
|
package/define/index.js
CHANGED
|
@@ -36,6 +36,7 @@ __export(define_exports, {
|
|
|
36
36
|
ChatCompletionContentPart: () => ChatCompletionContentPart,
|
|
37
37
|
ChatCompletionContentPartImage: () => ChatCompletionContentPartImage,
|
|
38
38
|
ChatCompletionContentPartStr: () => ChatCompletionContentPartStr,
|
|
39
|
+
ChatMessageCommonItemDefine: () => ChatMessageCommonItemDefine,
|
|
39
40
|
ChatMessageItemDefine: () => ChatMessageItemDefine,
|
|
40
41
|
ChatMessageListDefine: () => ChatMessageListDefine,
|
|
41
42
|
CompatSchema: () => CompatSchema,
|
|
@@ -64,8 +65,7 @@ var ChatCompletionContentPartStr = v.object({
|
|
|
64
65
|
});
|
|
65
66
|
var ChatCompletionContentPartImage = v.object({
|
|
66
67
|
image_url: v.object({
|
|
67
|
-
url: v.string()
|
|
68
|
-
detail: v.optional(v.picklist(["auto", "low", "high"]))
|
|
68
|
+
url: v.string()
|
|
69
69
|
}),
|
|
70
70
|
type: v.optional(v.literal("image_url"), "image_url")
|
|
71
71
|
});
|
|
@@ -97,6 +97,10 @@ var ChatMessageItemDefine = v.union([
|
|
|
97
97
|
UserChatMessage,
|
|
98
98
|
AssistantChatMessage
|
|
99
99
|
]);
|
|
100
|
+
var ChatMessageCommonItemDefine = v.union([
|
|
101
|
+
UserChatMessage,
|
|
102
|
+
AssistantChatMessage
|
|
103
|
+
]);
|
|
100
104
|
var ChatMessageListDefine = v.array(ChatMessageItemDefine);
|
|
101
105
|
|
|
102
106
|
// packages/openai/chat/util/get-custom-provider.ts
|
|
@@ -579,6 +583,7 @@ var ModelConfigDefine = v3.pipe(
|
|
|
579
583
|
ChatCompletionContentPart,
|
|
580
584
|
ChatCompletionContentPartImage,
|
|
581
585
|
ChatCompletionContentPartStr,
|
|
586
|
+
ChatMessageCommonItemDefine,
|
|
582
587
|
ChatMessageItemDefine,
|
|
583
588
|
ChatMessageListDefine,
|
|
584
589
|
CompatSchema,
|
package/define/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../packages/openai/define/index.ts", "../../../packages/openai/chat/message.define.ts", "../../../packages/openai/chat/util/get-custom-provider.ts", "../../../packages/openai/chat/provider.define.ts"],
|
|
4
|
-
"sourcesContent": ["export * from '../chat/message.define';\nexport * from '../chat/util/get-custom-provider'", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n detail: v.optional(v.picklist(['auto', 'low', 'high'])),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,QAAmB;AACZ,IAAM,+BAAiC,SAAO;AAAA,EACnD,MAAQ,SAAO;AAAA,EACf,MAAQ,WAAW,UAAQ,MAAM,GAAG,MAAM;AAC5C,CAAC;AAKM,IAAM,iCAAmC,SAAO;AAAA,EACrD,WAAa,SAAO;AAAA,IAClB,KAAO,SAAO;AAAA,
|
|
4
|
+
"sourcesContent": ["export * from '../chat/message.define';\nexport * from '../chat/util/get-custom-provider'", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport const ChatMessageCommonItemDefine = v.union([\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,QAAmB;AACZ,IAAM,+BAAiC,SAAO;AAAA,EACnD,MAAQ,SAAO;AAAA,EACf,MAAQ,WAAW,UAAQ,MAAM,GAAG,MAAM;AAC5C,CAAC;AAKM,IAAM,iCAAmC,SAAO;AAAA,EACrD,WAAa,SAAO;AAAA,IAClB,KAAO,SAAO;AAAA,EAChB,CAAC;AAAA,EACD,MAAQ,WAAW,UAAQ,WAAW,GAAG,WAAW;AACtD,CAAC;AAIM,IAAM,4BAA8B;AAAA,EACvC,QAAM,CAAC,8BAA8B,8BAA8B,CAAC;AACxE;AACO,IAAM,8BAAgC;AAAA,EAC3C;AACF;AACO,IAAM,4BAA4B;AAIlC,IAAM,iCAAmC;AAAA,EAC9C;AACF;AACO,IAAM,oBAAsB,SAAO;AAAA,EACxC,MAAQ,WAAW,UAAQ,QAAQ,GAAG,QAAQ;AAAA,EAC9C,SAAS;AACX,CAAC;AAEM,IAAM,kBAAoB,SAAO;AAAA,EACtC,MAAQ,WAAW,UAAQ,MAAM,GAAG,MAAM;AAAA,EAC1C,SAAS;AACX,CAAC;AAGM,IAAM,uBAAyB,SAAO;AAAA,EAC3C,MAAQ,WAAW,UAAQ,WAAW,GAAG,WAAW;AAAA,EACpD,SAAS;AAAA,EACT,cAAgB,WAAW,SAAO,CAAC;AACrC,CAAC;AAMM,IAAM,wBAA0B,QAAM;AAAA,EAC3C;AAAA,EACA;AAAA,EACA;AACF,CAAC;AACM,IAAM,8BAAgC,QAAM;AAAA,EACjD;AAAA,EACA;AACF,CAAC;AAEM,IAAM,wBAA0B,QAAM,qBAAqB;;;AC9DlE,IAAAA,KAAmB;AAEnB,mBAAgC;;;ACFhC,IAAAC,KAAmB;AAEZ,IAAM,sBAAwB;AAAA,EACjC,YAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAAA,IAEA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAAA,EACC,SAAM,KAAK;AAAA,EACX,eAAY,sEAAsE;AACtF;;;AD1CA,+BAAyB;AACzB,kBAAoB;AAEpB,SAAS,kBAGP,QACA,OACA,MACA,OACA;AACA,SAAO,EAAE,GAAG,OAAO,IAAI,OAAO,KAAK,QAAQ,KAAK;AAClD;AACO,SAAS,eAAe,OAA6B;AAC1D,MAAI,MAAM,aAAc,QAAgB;AACtC,WAAO;AAAA,MACL,OAAO,MAAM;AAAA,MACb,QAAQ;AAAA,IACV;AAAA,EACF;AACA,QAAM,SAAW,SAAM,mBAAmB,KAAK;AAC/C,MACE,OAAO,aAAa,wBACpB,OAAO,aAAa,sBACpB,OAAO,aAAa,sBACpB;AACA,WAAO;AAAA,MACL,OAAO;AAAA,QACL,OAAO;AAAA,QACP,OAAO;AAAA,QACP,OAAO;AAAA,QACP,OAAO;AAAA,MACT;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,WAAO,uBAAS,OAAO,UAAU,OAAO,KAAqB;AAAA,IAC7D;AAAA,EACF;AACF;AACO,IAAM,sBAAwB;AAAA,EACjC,YAAS,CAAC,WAAW,OAAO,UAAU,QAAQ,OAAO,CAAC;AAAA,EACtD,SAAM,MAAM;AAAA,EACZ,eAAY,kBAAkB;AAClC;AAEO,IAAM,2BAA6B;AAAA,EACtC,YAAS,CAAC,OAAO,WAAW,OAAO,UAAU,QAAQ,OAAO,CAAC;AAAA,EAC7D,SAAM,QAAQ;AAAA,EACd,eAAY,gBAAgB;AAChC;AAKO,IAAM,gCAAkC;AAAA,EAC3C;AAAA,IACE,UAAO;AAAA,MACP,eAAiB;AAAA,QACb;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,MAAM;AAAA,UACZ,eAAY,aAAa;AAAA,QAC7B;AAAA,MACF;AAAA,MACA,uBAAyB;AAAA,QACrB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,SAAS;AAAA,UACf,eAAY,uBAAuB;AAAA,QACvC;AAAA,MACF;AAAA,MACA,yBAA2B;AAAA,QACvB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,0BAA0B;AAAA,QAC1C;AAAA,MACF;AAAA,MACA,0BAA4B;AAAA,QACxB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,MAAM;AAAA,UACZ,eAAY,oBAAoB;AAAA,QACpC;AAAA,MACF;AAAA,MACA,gBAAkB;AAAA,QACd;AAAA,UACE,YAAS,CAAC,yBAAyB,YAAY,CAAC;AAAA,UAChD,SAAM,cAAc;AAAA,UACpB,eAAY,wBAAwB;AAAA,QACxC;AAAA,MACF;AAAA,MACA,wBAA0B;AAAA,QACtB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,UAAU;AAAA,UAChB,eAAY,sBAAsB;AAAA,QACtC;AAAA,MACF;AAAA,MACA,kCAAoC;AAAA,QAChC;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,iBAAiB;AAAA,QACjC;AAAA,MACF;AAAA,MACA,wBAA0B;AAAA,QACtB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,OAAO;AAAA,UACb,eAAY,iBAAiB;AAAA,QACjC;AAAA,MACF;AAAA,MACA,6CAA+C;AAAA,QAC3C;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,YAAY;AAAA,UAClB,eAAY,gBAAgB;AAAA,QAChC;AAAA,MACF;AAAA,MACA,gBAAkB;AAAA,QACd;AAAA,UACE,YAAS;AAAA,YACT;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,UACF,CAAC;AAAA,UACC,SAAM,MAAM;AAAA,UACZ,eAAY,sBAAsB;AAAA,QACtC;AAAA,MACF;AAAA,MACA,mBAAqB;AAAA,QACjB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,eAAe;AAAA,UACrB,eAAY,sBAAsB;AAAA,QACtC;AAAA,MACF;AAAA,MACA,sBAAwB;AAAA,QACpB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,mBAAmB;AAAA,UACzB,eAAY,6BAA6B;AAAA,QAC7C;AAAA,MACF;AAAA,MACA,eAAiB;AAAA,QACb;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,UAAU;AAAA,UAChB,eAAY,sBAAsB;AAAA,QACtC;AAAA,MACF;AAAA,MACA,oBAAsB;AAAA,QAClB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,MAAM;AAAA,UACZ,eAAY,0BAA0B;AAAA,QAC1C;AAAA,MACF;AAAA,MACA,oBAAsB;AAAA,QAClB;AAAA,UACE,WAAQ,WAAW;AAAA,UACnB,SAAM,QAAQ;AAAA,UACd,eAAY,aAAa;AAAA,QAC7B;AAAA,MACF;AAAA,MACA,4BAA8B;AAAA,QAC1B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,UAAU;AAAA,UAChB,eAAY,iBAAiB;AAAA,QACjC;AAAA,MACF;AAAA,MACA,4BAA8B;AAAA,QAC1B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,cAAc;AAAA,QAC9B;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EACE,SAAM,yBAAyB;AAAA,EAC/B,eAAY,oCAAoC;AACpD;AAGO,IAAM,8BAAgC;AAAA,EACzC;AAAA,IACE,UAAO;AAAA,MACP,uBAAyB;AAAA,QACrB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,SAAS;AAAA,UACf,eAAY,uBAAuB;AAAA,QACvC;AAAA,MACF;AAAA,MACA,qBAAuB;AAAA,QACnB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,YAAY;AAAA,UAClB,eAAY,0BAA0B;AAAA,QAC1C;AAAA,MACF;AAAA,MACA,4BAA8B;AAAA,QAC1B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,cAAc;AAAA,QAC9B;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EACE,SAAM,uBAAuB;AAAA,EAC7B,eAAY,kCAAkC;AAClD;AAGO,IAAM,gCAAkC;AAAA,EAC3C;AAAA,IACE,UAAO;AAAA,MACP,iCAAmC;AAAA,QAC/B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,eAAe;AAAA,UACrB,eAAY,wBAAwB;AAAA,QACxC;AAAA,MACF;AAAA,MACA,4BAA8B;AAAA,QAC1B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,cAAc;AAAA,QAC9B;AAAA,MACF;AAAA,MACA,4BAA8B;AAAA,QAC1B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,UAAU;AAAA,UAChB,eAAY,iBAAiB;AAAA,QACjC;AAAA,MACF;AAAA,MACA,6BAA+B;AAAA,QAC3B;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,oCAAoC;AAAA,QACpD;AAAA,MACF;AAAA,MACA,qBAAuB;AAAA,QACnB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,QAAQ;AAAA,UACd,eAAY,0BAA0B;AAAA,QAC1C;AAAA,MACF;AAAA,MACA,uBAAyB;AAAA,QACrB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,SAAS;AAAA,UACf,eAAY,6BAA6B;AAAA,QAC7C;AAAA,MACF;AAAA,MACA,qBAAuB;AAAA,QACnB;AAAA,UACE,WAAQ;AAAA,UACR,SAAM,OAAO;AAAA,UACb,eAAY,uBAAuB;AAAA,QACvC;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EACE,SAAM,yBAAyB;AAAA,EAC/B,eAAY,oCAAoC;AACpD;AAGO,IAAM,eAAiB;AAAA,EAC1B,SAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAAA,EACC,SAAM,MAAM;AAAA,EACZ;AAAA,IACA;AAAA,EACF;AACF;AAIO,IAAM,oBAAsB;AAAA,EAC/B,YAAS,CAAC,QAAQ,OAAO,CAAC;AAAA,EAC1B,SAAM,MAAM;AAAA,EACZ,eAAY,WAAW;AAC3B;AACO,IAAM,cAAgB;AAAA,EACzB,SAAM,iBAAiB;AAAA,EACvB,SAAM,QAAQ;AAAA,EACd,eAAY,kCAAkC;AAClD;AAIA,IAAM,gBAAkB;AAAA,EACpB,UAAS,UAAO,GAAK,UAAO,CAAC;AAAA,EAC7B,SAAM,QAAQ;AAAA,EACd,eAAY,mBAAmB;AACnC;AAKA,IAAM,aAAe;AAAA,EACjB;AAAA,IACE,UAAO;AAAA,MACP,OAAS;AAAA,QACL,UAAO;AAAA,QACP,SAAM,MAAM;AAAA,QACZ,eAAY,cAAc;AAAA,MAC9B;AAAA,MACA,QAAU;AAAA,QACN,UAAO;AAAA,QACP,SAAM,MAAM;AAAA,QACZ,eAAY,cAAc;AAAA,MAC9B;AAAA,MACA,WAAa;AAAA,QACT,UAAO;AAAA,QACP,SAAM,QAAQ;AAAA,QACd,eAAY,kBAAkB;AAAA,MAClC;AAAA,MACA,YAAc;AAAA,QACV,UAAO;AAAA,QACP,SAAM,QAAQ;AAAA,QACd,eAAY,iBAAiB;AAAA,MACjC;AAAA,IACF,CAAC;AAAA,IACD,EAAE,OAAO,GAAG,QAAQ,GAAG,WAAW,GAAG,YAAY,EAAE;AAAA,EACrD;AAAA,EACE,SAAM,MAAM;AAAA,EACZ,eAAY,qBAAqB;AACrC;AAGA,IAAM,yBAA2B;AAAA,EAC7B;AAAA,IACA;AAAA,IACE;AAAA,MACE,WAAU,UAAO,CAAC;AAAA,MAClB,SAAM,KAAK;AAAA,MACX,eAAY,2BAA2B;AAAA,IAC3C;AAAA,EACF;AAAA,EACE,SAAM,UAAU;AAAA,EAChB,eAAY,kBAAkB;AAClC;AAOO,IAAM,cAAgB;AAAA,EACzB,UAAO;AAAA,IACP,UAAY;AAAA,MACR,YAAW,UAAO,GAAG,SAAS;AAAA,MAC9B,SAAM,IAAI;AAAA,MACV,eAAY,oCAAoC;AAAA,IACpD;AAAA,IACA,SAAW;AAAA,MACP,UAAO;AAAA,MACP,SAAM,QAAQ;AAAA,MACd,eAAY,aAAa;AAAA,IAC7B;AAAA,IACA,WAAa;AAAA,MACT,YAAW,WAAQ,GAAG,KAAK;AAAA,MAC3B,SAAM,MAAM;AAAA,MACZ,eAAY,gBAAgB;AAAA,IAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,OAAS;AAAA,MACL,YAAS,aAAa,CAAC,QAAQ,OAAO,CAAC;AAAA,MACvC,SAAM,MAAM;AAAA,MACZ,eAAY,WAAW;AAAA,IAC3B;AAAA,IACA,MAAQ;AAAA,MACN;AAAA,MACE,SAAM,MAAM;AAAA,MACZ,eAAY,eAAe;AAAA,IAC/B;AAAA,IACA,eAAiB;AAAA,MACb,QAAO,YAAW,UAAO,GAAG,QAAQ,CAAC;AAAA,MACrC,SAAM,OAAO;AAAA,MACb,eAAY,oBAAoB;AAAA,IACpC;AAAA,IACA,WAAa;AAAA,MACT,QAAO,YAAW,UAAO,GAAG,QAAQ,CAAC;AAAA,MACrC,SAAM,aAAa;AAAA,MACnB,eAAY,qBAAqB;AAAA,IACrC;AAAA,IACA,SAAW;AAAA,MACP;AAAA,QACE,YAAS,aAAa;AAAA,QACtB,SAAM,QAAQ;AAAA,QACd,eAAY,gBAAgB;AAAA,MAChC;AAAA,IACF;AAAA,IACA,QAAU;AAAA,MACN,YAAS,cAAc,EAAE,uBAAuB,MAAM,CAAC;AAAA,MACvD,SAAM,MAAM;AAAA,MACZ,eAAY,aAAa;AAAA,IAC7B;AAAA,EACF,CAAC;AAAA,EACC,SAAM,MAAM;AAAA,EACZ;AAAA,IACA;AAAA,EACF;AACF;AAQO,IAAM,eAAe;AAErB,IAAM,oBAAsB;AAAA,EAC/B,UAAO;AAAA,IACP,UAAU;AAAA,IACV,OAAS,QAAO,UAAO,GAAK,SAAM,KAAK,CAAC;AAAA,IACxC,MAAQ;AAAA,MACJ,YAAW,UAAO,CAAC;AAAA,MACnB,SAAM,KAAK;AAAA,MACX,eAAY,iBAAiB;AAAA,IACjC;AAAA;AAAA,IAEA,QAAU,QAAO,YAAW,UAAO,CAAC,GAAK,SAAM,QAAQ,CAAC;AAAA,IACxD,QAAU;AAAA,MACN,YAAS,WAAW;AAAA,UACtB,mCAAS;AAAA,QACP,UAAU;AAAA,QACV,OAAO,IAAI,OAAO;AAChB,iBAAO,GAAG,EAAE,MAAM,CAAC,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,EAAE;AAAA,gBACxC;AAAA,cACE,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,MACf,EACE,UAAU,wBACV,UAAU,sBACV,UAAU;AAAA,YAEhB;AAAA,UACF;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF,CAAC;AAAA,EACC,aAAU,CAAC,UAAU,EAAE,GAAG,MAAM,MAAM,KAAK,QAAQ,KAAK,MAAM,EAAE;AACpE;",
|
|
6
6
|
"names": ["v", "v"]
|
|
7
7
|
}
|
package/define/index.mjs
CHANGED
|
@@ -6,8 +6,7 @@ var ChatCompletionContentPartStr = v.object({
|
|
|
6
6
|
});
|
|
7
7
|
var ChatCompletionContentPartImage = v.object({
|
|
8
8
|
image_url: v.object({
|
|
9
|
-
url: v.string()
|
|
10
|
-
detail: v.optional(v.picklist(["auto", "low", "high"]))
|
|
9
|
+
url: v.string()
|
|
11
10
|
}),
|
|
12
11
|
type: v.optional(v.literal("image_url"), "image_url")
|
|
13
12
|
});
|
|
@@ -39,6 +38,10 @@ var ChatMessageItemDefine = v.union([
|
|
|
39
38
|
UserChatMessage,
|
|
40
39
|
AssistantChatMessage
|
|
41
40
|
]);
|
|
41
|
+
var ChatMessageCommonItemDefine = v.union([
|
|
42
|
+
UserChatMessage,
|
|
43
|
+
AssistantChatMessage
|
|
44
|
+
]);
|
|
42
45
|
var ChatMessageListDefine = v.array(ChatMessageItemDefine);
|
|
43
46
|
|
|
44
47
|
// packages/openai/chat/util/get-custom-provider.ts
|
|
@@ -520,6 +523,7 @@ export {
|
|
|
520
523
|
ChatCompletionContentPart,
|
|
521
524
|
ChatCompletionContentPartImage,
|
|
522
525
|
ChatCompletionContentPartStr,
|
|
526
|
+
ChatMessageCommonItemDefine,
|
|
523
527
|
ChatMessageItemDefine,
|
|
524
528
|
ChatMessageListDefine,
|
|
525
529
|
CompatSchema,
|
package/define/index.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../packages/openai/chat/message.define.ts", "../../../packages/openai/chat/util/get-custom-provider.ts", "../../../packages/openai/chat/provider.define.ts"],
|
|
4
|
-
"sourcesContent": ["import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n detail: v.optional(v.picklist(['auto', 'low', 'high'])),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n"],
|
|
5
|
-
"mappings": ";AAAA,YAAY,OAAO;AACZ,IAAM,+BAAiC,SAAO;AAAA,EACnD,MAAQ,SAAO;AAAA,EACf,MAAQ,WAAW,UAAQ,MAAM,GAAG,MAAM;AAC5C,CAAC;AAKM,IAAM,iCAAmC,SAAO;AAAA,EACrD,WAAa,SAAO;AAAA,IAClB,KAAO,SAAO;AAAA,
|
|
4
|
+
"sourcesContent": ["import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport const ChatMessageCommonItemDefine = v.union([\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["v", "v"]
|
|
7
7
|
}
|
package/index.js
CHANGED
|
@@ -36,6 +36,7 @@ __export(openai_exports, {
|
|
|
36
36
|
ChatCompletionContentPart: () => ChatCompletionContentPart,
|
|
37
37
|
ChatCompletionContentPartImage: () => ChatCompletionContentPartImage,
|
|
38
38
|
ChatCompletionContentPartStr: () => ChatCompletionContentPartStr,
|
|
39
|
+
ChatMessageCommonItemDefine: () => ChatMessageCommonItemDefine,
|
|
39
40
|
ChatMessageItemDefine: () => ChatMessageItemDefine,
|
|
40
41
|
ChatMessageListDefine: () => ChatMessageListDefine,
|
|
41
42
|
CompatSchema: () => CompatSchema,
|
|
@@ -83,8 +84,7 @@ var ChatCompletionContentPartStr = v.object({
|
|
|
83
84
|
});
|
|
84
85
|
var ChatCompletionContentPartImage = v.object({
|
|
85
86
|
image_url: v.object({
|
|
86
|
-
url: v.string()
|
|
87
|
-
detail: v.optional(v.picklist(["auto", "low", "high"]))
|
|
87
|
+
url: v.string()
|
|
88
88
|
}),
|
|
89
89
|
type: v.optional(v.literal("image_url"), "image_url")
|
|
90
90
|
});
|
|
@@ -116,6 +116,10 @@ var ChatMessageItemDefine = v.union([
|
|
|
116
116
|
UserChatMessage,
|
|
117
117
|
AssistantChatMessage
|
|
118
118
|
]);
|
|
119
|
+
var ChatMessageCommonItemDefine = v.union([
|
|
120
|
+
UserChatMessage,
|
|
121
|
+
AssistantChatMessage
|
|
122
|
+
]);
|
|
119
123
|
var ChatMessageListDefine = v.array(ChatMessageItemDefine);
|
|
120
124
|
|
|
121
125
|
// packages/openai/chat/util/create.ts
|
|
@@ -619,10 +623,62 @@ var ModelConfigDefine = v3.pipe(
|
|
|
619
623
|
|
|
620
624
|
// packages/openai/chat/chat.ts
|
|
621
625
|
var import_util = require("@cyia/util");
|
|
626
|
+
var v4 = __toESM(require("valibot"), 1);
|
|
622
627
|
function createChatStream(input) {
|
|
623
628
|
const result = getModelConfig(input);
|
|
624
629
|
return (context, options, extra) => {
|
|
625
630
|
context.messages = (0, import_util.deepClone)(context.messages);
|
|
631
|
+
const PiPUserConvertDefine = v4.pipe(
|
|
632
|
+
UserChatMessage,
|
|
633
|
+
v4.transform(
|
|
634
|
+
(item) => ({
|
|
635
|
+
role: "user",
|
|
636
|
+
timestamp: Date.now(),
|
|
637
|
+
content: item.content.map((item2) => {
|
|
638
|
+
if (item2.type === "text") {
|
|
639
|
+
return item2;
|
|
640
|
+
} else {
|
|
641
|
+
const match = item2.image_url.url.match(
|
|
642
|
+
/^data:([^;]+);base64,(.+)$/
|
|
643
|
+
);
|
|
644
|
+
return {
|
|
645
|
+
type: "image",
|
|
646
|
+
mimeType: match[1],
|
|
647
|
+
data: match[2]
|
|
648
|
+
};
|
|
649
|
+
}
|
|
650
|
+
})
|
|
651
|
+
})
|
|
652
|
+
)
|
|
653
|
+
);
|
|
654
|
+
const PiPAssConvertDefine = v4.pipe(
|
|
655
|
+
AssistantChatMessage,
|
|
656
|
+
v4.transform(
|
|
657
|
+
(item) => ({
|
|
658
|
+
role: "assistant",
|
|
659
|
+
timestamp: Date.now(),
|
|
660
|
+
content: item.content.map((item2) => item2),
|
|
661
|
+
api: result.model.api,
|
|
662
|
+
provider: result.model.provider,
|
|
663
|
+
usage: {
|
|
664
|
+
cacheRead: 0,
|
|
665
|
+
cacheWrite: 0,
|
|
666
|
+
cost: {
|
|
667
|
+
input: 0,
|
|
668
|
+
output: 0,
|
|
669
|
+
cacheRead: 0,
|
|
670
|
+
cacheWrite: 0,
|
|
671
|
+
total: 0
|
|
672
|
+
},
|
|
673
|
+
input: 0,
|
|
674
|
+
output: 0,
|
|
675
|
+
totalTokens: 0
|
|
676
|
+
},
|
|
677
|
+
stopReason: "stop",
|
|
678
|
+
model: result.model.api
|
|
679
|
+
})
|
|
680
|
+
)
|
|
681
|
+
);
|
|
626
682
|
const sysIndex = context.messages.findIndex(
|
|
627
683
|
(item) => item.role === "system"
|
|
628
684
|
);
|
|
@@ -631,20 +687,30 @@ function createChatStream(input) {
|
|
|
631
687
|
context.messages.splice(sysIndex, 1);
|
|
632
688
|
context.systemPrompt = item.content[0].text;
|
|
633
689
|
}
|
|
634
|
-
const createStream = () => (0, import_pi_ai2.stream)(
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
690
|
+
const createStream = () => (0, import_pi_ai2.stream)(
|
|
691
|
+
result.model,
|
|
692
|
+
{
|
|
693
|
+
...context,
|
|
694
|
+
messages: v4.parse(
|
|
695
|
+
v4.array(v4.union([PiPUserConvertDefine, PiPAssConvertDefine])),
|
|
696
|
+
context.messages
|
|
697
|
+
)
|
|
698
|
+
},
|
|
699
|
+
{
|
|
700
|
+
...options,
|
|
701
|
+
apiKey: options?.apiKey ?? result.config.apiKey,
|
|
702
|
+
onPayload(payload, model) {
|
|
703
|
+
payload = options?.onPayload?.(payload, model) ?? payload;
|
|
704
|
+
if (model.api === "openai-completions") {
|
|
705
|
+
return {
|
|
706
|
+
...payload,
|
|
707
|
+
response_format: extra?.response_format
|
|
708
|
+
};
|
|
709
|
+
}
|
|
710
|
+
return payload;
|
|
644
711
|
}
|
|
645
|
-
return payload;
|
|
646
712
|
}
|
|
647
|
-
|
|
713
|
+
);
|
|
648
714
|
let currentStream = createStream();
|
|
649
715
|
const config = extra?.injector?.get(OpenAIConfigToken);
|
|
650
716
|
return (async function* () {
|
|
@@ -703,6 +769,7 @@ function registerMockProvider(options) {
|
|
|
703
769
|
ChatCompletionContentPart,
|
|
704
770
|
ChatCompletionContentPartImage,
|
|
705
771
|
ChatCompletionContentPartStr,
|
|
772
|
+
ChatMessageCommonItemDefine,
|
|
706
773
|
ChatMessageItemDefine,
|
|
707
774
|
ChatMessageListDefine,
|
|
708
775
|
CompatSchema,
|
package/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../packages/openai/index.ts", "../../packages/openai/chat/token.ts", "../../packages/openai/chat/message.define.ts", "../../packages/openai/chat/util/create.ts", "../../packages/openai/chat/module.ts", "../../packages/openai/chat/chat.ts", "../../packages/openai/chat/util/get-custom-provider.ts", "../../packages/openai/chat/provider.define.ts", "../../packages/openai/chat/util/faux-provider.ts"],
|
|
4
|
-
"sourcesContent": ["export * from './chat/token';\nexport * from './chat/message.define';\nexport * from './chat/util/create';\nexport * from './chat/type/history';\nexport * from './chat/type';\nexport * from './chat/module';\nexport * from './chat/chat'\nexport * from './chat/util/get-custom-provider'\nexport { complete, stream, fauxAssistantMessage, fauxText, fauxThinking } from '@earendil-works/pi-ai'\nexport * from './chat/util/faux-provider'", "import { InjectionToken, Signal } from 'static-injector';\nimport { OpenAIConfig } from './type';\n\nexport const OpenAIConfigToken = new InjectionToken<Signal<OpenAIConfig>>(\n 'OpenAIConfig',\n);\n", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n detail: v.optional(v.picklist(['auto', 'low', 'high'])),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import {\n AssistantChatMessageType,\n SystemChatMessageType,\n UserChatMessageType,\n} from '../message.define';\n\nexport function createSystemMessage() {\n return { role: 'system' } as SystemChatMessageType;\n}\nexport function createUserMessage(text?: string) {\n return {\n role: 'user',\n content:\n typeof text === 'string' ? [{ type: 'text', text: '' }] : undefined,\n } as UserChatMessageType;\n}\nexport function createAssistantMessage(text: string = '') {\n return {\n role: 'assistant',\n content: [{ type: 'text', text }],\n } as AssistantChatMessageType;\n}\n", "import { OpenAIConfigToken } from './token';\n\nexport const OPENAI_MODULE = {\n provider: [],\n token: { OpenAIConfigToken },\n};\n", "import { Context, stream, StreamOptions } from '@earendil-works/pi-ai';\nimport {\n getModelConfig,\n ModelConfigInputType,\n} from './util/get-custom-provider';\nimport type OpenAI from 'openai';\nimport { SystemChatMessageType } from './message.define';\nimport { deepClone } from '@cyia/util';\nimport { Injector } from 'static-injector';\nimport { OpenAIConfigToken } from './token';\n\nexport function createChatStream(input: ModelConfigInputType) {\n const result = getModelConfig(input);\n return (\n context: Context,\n options?: StreamOptions,\n extra?: {\n response_format?: OpenAI.Chat.Completions.ChatCompletionCreateParamsStreaming['response_format'];\n injector?: Injector;\n },\n ) => {\n context.messages = deepClone(context.messages);\n // todo 系统类型在输入时未处理\n const sysIndex = context.messages.findIndex(\n (item) => item.role === ('system' as any),\n );\n if (sysIndex !== -1) {\n const item = context.messages[sysIndex] as any as SystemChatMessageType;\n context.messages.splice(sysIndex, 1);\n context.systemPrompt = item.content[0].text;\n }\n const createStream = () =>\n stream(result.model, context, {\n ...options,\n apiKey: options?.apiKey ?? result.config.apiKey,\n onPayload(payload, model) {\n payload = options?.onPayload?.(payload, model) ?? payload;\n if (model.api === 'openai-completions') {\n return {\n ...(payload as any),\n response_format: extra?.response_format,\n };\n }\n return payload;\n },\n });\n\n let currentStream = createStream();\n const config = extra?.injector?.get(OpenAIConfigToken);\n return (async function* () {\n let hasRetry = false;\n while (true) {\n let retry = false;\n for await (const item of currentStream) {\n if (item.type === 'error') {\n if (\n item.error.errorMessage?.includes('404') &&\n item.error.errorMessage?.includes(\n 'no router for requested model',\n ) &&\n !hasRetry\n ) {\n if (config?.().tryPull?.()) {\n await config().pullModel?.(input.model);\n retry = true;\n break;\n }\n }\n }\n yield item;\n }\n if (!retry || hasRetry) {\n break;\n }\n hasRetry = true;\n currentStream = createStream();\n }\n })();\n };\n}\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n", "import {\n registerFauxProvider,\n fauxAssistantMessage,\n fauxText,\n Context,\n StreamOptions,\n FauxResponseStep,\n} from '@earendil-works/pi-ai';\n\n/**\n * 创建一个基于用户输入动态返回响应的方法。\n * @param responseFactory - 根据上下文动态生成响应的工厂函数,接收历史消息和调用序号,返回文本或文本数组\n */\nexport function createDynamicResponse(\n responseFactory: (context: Context, callCount: number) => string | string[],\n) {\n return async (\n context: Context,\n _options: StreamOptions | undefined,\n state: { callCount: number },\n ) => {\n const responses = responseFactory(context, state.callCount);\n const content = Array.isArray(responses)\n ? responses.map((r) => fauxText(r))\n : fauxText(responses);\n return fauxAssistantMessage(content);\n };\n}\n\n/** Options for registerFauxProvider. */\nexport interface MockProviderOptions {\n api?: string;\n provider?: string;\n tokensPerSecond?: number;\n}\n\n\n\n/**\n * Register a faux mock provider and return a ready-to-use model with cleanup.\n * \n * @example\n * ```ts\n * const { model, setResponses, unregister } = registerMockProvider();\n * setResponses([fauxAssistantMessage('hello')]);\n * const response = await complete(model, { messages: [{ role: 'user', content: 'hi', timestamp: Date.now() }] });\n * unregister(); // clean up when done\n * ```\n */\nexport function registerMockProvider(\n options?: MockProviderOptions,\n) {\n const registration = registerFauxProvider(options);\n\n return {\n model: registration.getModel(),\n setResponses: (responses: FauxResponseStep[]) => registration.setResponses(responses),\n unregister: () => registration.unregister(),\n };\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_pi_ai", "v", "v", "import_pi_ai", "import_pi_ai"]
|
|
4
|
+
"sourcesContent": ["export * from './chat/token';\nexport * from './chat/message.define';\nexport * from './chat/util/create';\nexport * from './chat/type/history';\nexport * from './chat/type';\nexport * from './chat/module';\nexport * from './chat/chat'\nexport * from './chat/util/get-custom-provider'\nexport { complete, stream, fauxAssistantMessage, fauxText, fauxThinking } from '@earendil-works/pi-ai'\nexport * from './chat/util/faux-provider'", "import { InjectionToken, Signal } from 'static-injector';\nimport { OpenAIConfig } from './type';\n\nexport const OpenAIConfigToken = new InjectionToken<Signal<OpenAIConfig>>(\n 'OpenAIConfig',\n);\n", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport const ChatMessageCommonItemDefine = v.union([\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import {\n AssistantChatMessageType,\n SystemChatMessageType,\n UserChatMessageType,\n} from '../message.define';\n\nexport function createSystemMessage() {\n return { role: 'system' } as SystemChatMessageType;\n}\nexport function createUserMessage(text?: string) {\n return {\n role: 'user',\n content:\n typeof text === 'string' ? [{ type: 'text', text: '' }] : undefined,\n } as UserChatMessageType;\n}\nexport function createAssistantMessage(text: string = '') {\n return {\n role: 'assistant',\n content: [{ type: 'text', text }],\n } as AssistantChatMessageType;\n}\n", "import { OpenAIConfigToken } from './token';\n\nexport const OPENAI_MODULE = {\n provider: [],\n token: { OpenAIConfigToken },\n};\n", "import {\n AssistantMessage,\n Context,\n stream,\n StreamOptions,\n UserMessage,\n} from '@earendil-works/pi-ai';\nimport {\n getModelConfig,\n ModelConfigInputType,\n} from './util/get-custom-provider';\nimport type OpenAI from 'openai';\nimport {\n AssistantChatMessage,\n ChatMessageItemType,\n SystemChatMessageType,\n UserChatMessage,\n} from './message.define';\nimport { deepClone } from '@cyia/util';\nimport { Injector } from 'static-injector';\nimport { OpenAIConfigToken } from './token';\nimport * as v from 'valibot';\n\nexport function createChatStream(input: ModelConfigInputType) {\n const result = getModelConfig(input);\n return (\n context: Omit<Context, 'messages'> & { messages: ChatMessageItemType[] },\n options?: StreamOptions,\n extra?: {\n response_format?: OpenAI.Chat.Completions.ChatCompletionCreateParamsStreaming['response_format'];\n injector?: Injector;\n },\n ) => {\n context.messages = deepClone(context.messages);\n const PiPUserConvertDefine = v.pipe(\n UserChatMessage,\n v.transform(\n (item) =>\n ({\n role: 'user',\n timestamp: Date.now(),\n content: item.content.map((item) => {\n if (item.type === 'text') {\n return item;\n } else {\n const match = item.image_url.url.match(\n /^data:([^;]+);base64,(.+)$/,\n );\n return {\n type: 'image',\n mimeType: match![1],\n data: match![2],\n };\n }\n }),\n }) satisfies UserMessage,\n ),\n );\n const PiPAssConvertDefine = v.pipe(\n AssistantChatMessage,\n v.transform(\n (item) =>\n ({\n role: 'assistant',\n timestamp: Date.now(),\n content: item.content.map((item) => item),\n api: result.model.api,\n provider: result.model.provider,\n usage: {\n cacheRead: 0,\n cacheWrite: 0,\n cost: {\n input: 0,\n output: 0,\n cacheRead: 0,\n cacheWrite: 0,\n total: 0,\n },\n input: 0,\n output: 0,\n totalTokens: 0,\n },\n stopReason: 'stop',\n model: result.model.api,\n }) satisfies AssistantMessage,\n ),\n );\n // todo 系统类型在输入时未处理\n const sysIndex = context.messages.findIndex(\n (item) => item.role === 'system',\n );\n if (sysIndex !== -1) {\n const item = context.messages[sysIndex] as any as SystemChatMessageType;\n context.messages.splice(sysIndex, 1);\n context.systemPrompt = item.content[0].text;\n }\n const createStream = () =>\n stream(\n result.model,\n {\n ...context,\n messages: v.parse(\n v.array(v.union([PiPUserConvertDefine, PiPAssConvertDefine])),\n context.messages,\n ),\n },\n {\n ...options,\n\n apiKey: options?.apiKey ?? result.config.apiKey,\n onPayload(payload, model) {\n payload = options?.onPayload?.(payload, model) ?? payload;\n if (model.api === 'openai-completions') {\n return {\n ...(payload as any),\n response_format: extra?.response_format,\n };\n }\n return payload;\n },\n },\n );\n\n let currentStream = createStream();\n const config = extra?.injector?.get(OpenAIConfigToken);\n return (async function* () {\n let hasRetry = false;\n while (true) {\n let retry = false;\n for await (const item of currentStream) {\n if (item.type === 'error') {\n if (\n item.error.errorMessage?.includes('404') &&\n item.error.errorMessage?.includes(\n 'no router for requested model',\n ) &&\n !hasRetry\n ) {\n if (config?.().tryPull?.()) {\n await config().pullModel?.(input.model);\n retry = true;\n break;\n }\n }\n }\n yield item;\n }\n if (!retry || hasRetry) {\n break;\n }\n hasRetry = true;\n currentStream = createStream();\n }\n })();\n };\n}\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n", "import {\n registerFauxProvider,\n fauxAssistantMessage,\n fauxText,\n Context,\n StreamOptions,\n FauxResponseStep,\n} from '@earendil-works/pi-ai';\n\n/**\n * 创建一个基于用户输入动态返回响应的方法。\n * @param responseFactory - 根据上下文动态生成响应的工厂函数,接收历史消息和调用序号,返回文本或文本数组\n */\nexport function createDynamicResponse(\n responseFactory: (context: Context, callCount: number) => string | string[],\n) {\n return async (\n context: Context,\n _options: StreamOptions | undefined,\n state: { callCount: number },\n ) => {\n const responses = responseFactory(context, state.callCount);\n const content = Array.isArray(responses)\n ? responses.map((r) => fauxText(r))\n : fauxText(responses);\n return fauxAssistantMessage(content);\n };\n}\n\n/** Options for registerFauxProvider. */\nexport interface MockProviderOptions {\n api?: string;\n provider?: string;\n tokensPerSecond?: number;\n}\n\n\n\n/**\n * Register a faux mock provider and return a ready-to-use model with cleanup.\n * \n * @example\n * ```ts\n * const { model, setResponses, unregister } = registerMockProvider();\n * setResponses([fauxAssistantMessage('hello')]);\n * const response = await complete(model, { messages: [{ role: 'user', content: 'hi', timestamp: Date.now() }] });\n * unregister(); // clean up when done\n * ```\n */\nexport function registerMockProvider(\n options?: MockProviderOptions,\n) {\n const registration = registerFauxProvider(options);\n\n return {\n model: registration.getModel(),\n setResponses: (responses: FauxResponseStep[]) => registration.setResponses(responses),\n unregister: () => registration.unregister(),\n };\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_pi_ai", "v", "v", "v", "item", "import_pi_ai", "import_pi_ai"]
|
|
7
7
|
}
|
package/index.mjs
CHANGED
|
@@ -12,8 +12,7 @@ var ChatCompletionContentPartStr = v.object({
|
|
|
12
12
|
});
|
|
13
13
|
var ChatCompletionContentPartImage = v.object({
|
|
14
14
|
image_url: v.object({
|
|
15
|
-
url: v.string()
|
|
16
|
-
detail: v.optional(v.picklist(["auto", "low", "high"]))
|
|
15
|
+
url: v.string()
|
|
17
16
|
}),
|
|
18
17
|
type: v.optional(v.literal("image_url"), "image_url")
|
|
19
18
|
});
|
|
@@ -45,6 +44,10 @@ var ChatMessageItemDefine = v.union([
|
|
|
45
44
|
UserChatMessage,
|
|
46
45
|
AssistantChatMessage
|
|
47
46
|
]);
|
|
47
|
+
var ChatMessageCommonItemDefine = v.union([
|
|
48
|
+
UserChatMessage,
|
|
49
|
+
AssistantChatMessage
|
|
50
|
+
]);
|
|
48
51
|
var ChatMessageListDefine = v.array(ChatMessageItemDefine);
|
|
49
52
|
|
|
50
53
|
// packages/openai/chat/util/create.ts
|
|
@@ -71,7 +74,9 @@ var OPENAI_MODULE = {
|
|
|
71
74
|
};
|
|
72
75
|
|
|
73
76
|
// packages/openai/chat/chat.ts
|
|
74
|
-
import {
|
|
77
|
+
import {
|
|
78
|
+
stream
|
|
79
|
+
} from "@earendil-works/pi-ai";
|
|
75
80
|
|
|
76
81
|
// packages/openai/chat/util/get-custom-provider.ts
|
|
77
82
|
import * as v3 from "valibot";
|
|
@@ -548,10 +553,62 @@ var ModelConfigDefine = v3.pipe(
|
|
|
548
553
|
|
|
549
554
|
// packages/openai/chat/chat.ts
|
|
550
555
|
import { deepClone } from "@cyia/util";
|
|
556
|
+
import * as v4 from "valibot";
|
|
551
557
|
function createChatStream(input) {
|
|
552
558
|
const result = getModelConfig(input);
|
|
553
559
|
return (context, options, extra) => {
|
|
554
560
|
context.messages = deepClone(context.messages);
|
|
561
|
+
const PiPUserConvertDefine = v4.pipe(
|
|
562
|
+
UserChatMessage,
|
|
563
|
+
v4.transform(
|
|
564
|
+
(item) => ({
|
|
565
|
+
role: "user",
|
|
566
|
+
timestamp: Date.now(),
|
|
567
|
+
content: item.content.map((item2) => {
|
|
568
|
+
if (item2.type === "text") {
|
|
569
|
+
return item2;
|
|
570
|
+
} else {
|
|
571
|
+
const match = item2.image_url.url.match(
|
|
572
|
+
/^data:([^;]+);base64,(.+)$/
|
|
573
|
+
);
|
|
574
|
+
return {
|
|
575
|
+
type: "image",
|
|
576
|
+
mimeType: match[1],
|
|
577
|
+
data: match[2]
|
|
578
|
+
};
|
|
579
|
+
}
|
|
580
|
+
})
|
|
581
|
+
})
|
|
582
|
+
)
|
|
583
|
+
);
|
|
584
|
+
const PiPAssConvertDefine = v4.pipe(
|
|
585
|
+
AssistantChatMessage,
|
|
586
|
+
v4.transform(
|
|
587
|
+
(item) => ({
|
|
588
|
+
role: "assistant",
|
|
589
|
+
timestamp: Date.now(),
|
|
590
|
+
content: item.content.map((item2) => item2),
|
|
591
|
+
api: result.model.api,
|
|
592
|
+
provider: result.model.provider,
|
|
593
|
+
usage: {
|
|
594
|
+
cacheRead: 0,
|
|
595
|
+
cacheWrite: 0,
|
|
596
|
+
cost: {
|
|
597
|
+
input: 0,
|
|
598
|
+
output: 0,
|
|
599
|
+
cacheRead: 0,
|
|
600
|
+
cacheWrite: 0,
|
|
601
|
+
total: 0
|
|
602
|
+
},
|
|
603
|
+
input: 0,
|
|
604
|
+
output: 0,
|
|
605
|
+
totalTokens: 0
|
|
606
|
+
},
|
|
607
|
+
stopReason: "stop",
|
|
608
|
+
model: result.model.api
|
|
609
|
+
})
|
|
610
|
+
)
|
|
611
|
+
);
|
|
555
612
|
const sysIndex = context.messages.findIndex(
|
|
556
613
|
(item) => item.role === "system"
|
|
557
614
|
);
|
|
@@ -560,20 +617,30 @@ function createChatStream(input) {
|
|
|
560
617
|
context.messages.splice(sysIndex, 1);
|
|
561
618
|
context.systemPrompt = item.content[0].text;
|
|
562
619
|
}
|
|
563
|
-
const createStream = () => stream(
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
620
|
+
const createStream = () => stream(
|
|
621
|
+
result.model,
|
|
622
|
+
{
|
|
623
|
+
...context,
|
|
624
|
+
messages: v4.parse(
|
|
625
|
+
v4.array(v4.union([PiPUserConvertDefine, PiPAssConvertDefine])),
|
|
626
|
+
context.messages
|
|
627
|
+
)
|
|
628
|
+
},
|
|
629
|
+
{
|
|
630
|
+
...options,
|
|
631
|
+
apiKey: options?.apiKey ?? result.config.apiKey,
|
|
632
|
+
onPayload(payload, model) {
|
|
633
|
+
payload = options?.onPayload?.(payload, model) ?? payload;
|
|
634
|
+
if (model.api === "openai-completions") {
|
|
635
|
+
return {
|
|
636
|
+
...payload,
|
|
637
|
+
response_format: extra?.response_format
|
|
638
|
+
};
|
|
639
|
+
}
|
|
640
|
+
return payload;
|
|
573
641
|
}
|
|
574
|
-
return payload;
|
|
575
642
|
}
|
|
576
|
-
|
|
643
|
+
);
|
|
577
644
|
let currentStream = createStream();
|
|
578
645
|
const config = extra?.injector?.get(OpenAIConfigToken);
|
|
579
646
|
return (async function* () {
|
|
@@ -635,6 +702,7 @@ export {
|
|
|
635
702
|
ChatCompletionContentPart,
|
|
636
703
|
ChatCompletionContentPartImage,
|
|
637
704
|
ChatCompletionContentPartStr,
|
|
705
|
+
ChatMessageCommonItemDefine,
|
|
638
706
|
ChatMessageItemDefine,
|
|
639
707
|
ChatMessageListDefine,
|
|
640
708
|
CompatSchema,
|
package/index.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../packages/openai/chat/token.ts", "../../packages/openai/chat/message.define.ts", "../../packages/openai/chat/util/create.ts", "../../packages/openai/chat/module.ts", "../../packages/openai/chat/chat.ts", "../../packages/openai/chat/util/get-custom-provider.ts", "../../packages/openai/chat/provider.define.ts", "../../packages/openai/index.ts", "../../packages/openai/chat/util/faux-provider.ts"],
|
|
4
|
-
"sourcesContent": ["import { InjectionToken, Signal } from 'static-injector';\nimport { OpenAIConfig } from './type';\n\nexport const OpenAIConfigToken = new InjectionToken<Signal<OpenAIConfig>>(\n 'OpenAIConfig',\n);\n", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n detail: v.optional(v.picklist(['auto', 'low', 'high'])),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import {\n AssistantChatMessageType,\n SystemChatMessageType,\n UserChatMessageType,\n} from '../message.define';\n\nexport function createSystemMessage() {\n return { role: 'system' } as SystemChatMessageType;\n}\nexport function createUserMessage(text?: string) {\n return {\n role: 'user',\n content:\n typeof text === 'string' ? [{ type: 'text', text: '' }] : undefined,\n } as UserChatMessageType;\n}\nexport function createAssistantMessage(text: string = '') {\n return {\n role: 'assistant',\n content: [{ type: 'text', text }],\n } as AssistantChatMessageType;\n}\n", "import { OpenAIConfigToken } from './token';\n\nexport const OPENAI_MODULE = {\n provider: [],\n token: { OpenAIConfigToken },\n};\n", "import { Context, stream, StreamOptions } from '@earendil-works/pi-ai';\nimport {\n getModelConfig,\n ModelConfigInputType,\n} from './util/get-custom-provider';\nimport type OpenAI from 'openai';\nimport { SystemChatMessageType } from './message.define';\nimport { deepClone } from '@cyia/util';\nimport { Injector } from 'static-injector';\nimport { OpenAIConfigToken } from './token';\n\nexport function createChatStream(input: ModelConfigInputType) {\n const result = getModelConfig(input);\n return (\n context: Context,\n options?: StreamOptions,\n extra?: {\n response_format?: OpenAI.Chat.Completions.ChatCompletionCreateParamsStreaming['response_format'];\n injector?: Injector;\n },\n ) => {\n context.messages = deepClone(context.messages);\n // todo 系统类型在输入时未处理\n const sysIndex = context.messages.findIndex(\n (item) => item.role === ('system' as any),\n );\n if (sysIndex !== -1) {\n const item = context.messages[sysIndex] as any as SystemChatMessageType;\n context.messages.splice(sysIndex, 1);\n context.systemPrompt = item.content[0].text;\n }\n const createStream = () =>\n stream(result.model, context, {\n ...options,\n apiKey: options?.apiKey ?? result.config.apiKey,\n onPayload(payload, model) {\n payload = options?.onPayload?.(payload, model) ?? payload;\n if (model.api === 'openai-completions') {\n return {\n ...(payload as any),\n response_format: extra?.response_format,\n };\n }\n return payload;\n },\n });\n\n let currentStream = createStream();\n const config = extra?.injector?.get(OpenAIConfigToken);\n return (async function* () {\n let hasRetry = false;\n while (true) {\n let retry = false;\n for await (const item of currentStream) {\n if (item.type === 'error') {\n if (\n item.error.errorMessage?.includes('404') &&\n item.error.errorMessage?.includes(\n 'no router for requested model',\n ) &&\n !hasRetry\n ) {\n if (config?.().tryPull?.()) {\n await config().pullModel?.(input.model);\n retry = true;\n break;\n }\n }\n }\n yield item;\n }\n if (!retry || hasRetry) {\n break;\n }\n hasRetry = true;\n currentStream = createStream();\n }\n })();\n };\n}\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n", "export * from './chat/token';\nexport * from './chat/message.define';\nexport * from './chat/util/create';\nexport * from './chat/type/history';\nexport * from './chat/type';\nexport * from './chat/module';\nexport * from './chat/chat'\nexport * from './chat/util/get-custom-provider'\nexport { complete, stream, fauxAssistantMessage, fauxText, fauxThinking } from '@earendil-works/pi-ai'\nexport * from './chat/util/faux-provider'", "import {\n registerFauxProvider,\n fauxAssistantMessage,\n fauxText,\n Context,\n StreamOptions,\n FauxResponseStep,\n} from '@earendil-works/pi-ai';\n\n/**\n * 创建一个基于用户输入动态返回响应的方法。\n * @param responseFactory - 根据上下文动态生成响应的工厂函数,接收历史消息和调用序号,返回文本或文本数组\n */\nexport function createDynamicResponse(\n responseFactory: (context: Context, callCount: number) => string | string[],\n) {\n return async (\n context: Context,\n _options: StreamOptions | undefined,\n state: { callCount: number },\n ) => {\n const responses = responseFactory(context, state.callCount);\n const content = Array.isArray(responses)\n ? responses.map((r) => fauxText(r))\n : fauxText(responses);\n return fauxAssistantMessage(content);\n };\n}\n\n/** Options for registerFauxProvider. */\nexport interface MockProviderOptions {\n api?: string;\n provider?: string;\n tokensPerSecond?: number;\n}\n\n\n\n/**\n * Register a faux mock provider and return a ready-to-use model with cleanup.\n * \n * @example\n * ```ts\n * const { model, setResponses, unregister } = registerMockProvider();\n * setResponses([fauxAssistantMessage('hello')]);\n * const response = await complete(model, { messages: [{ role: 'user', content: 'hi', timestamp: Date.now() }] });\n * unregister(); // clean up when done\n * ```\n */\nexport function registerMockProvider(\n options?: MockProviderOptions,\n) {\n const registration = registerFauxProvider(options);\n\n return {\n model: registration.getModel(),\n setResponses: (responses: FauxResponseStep[]) => registration.setResponses(responses),\n unregister: () => registration.unregister(),\n };\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["v", "v", "stream", "fauxAssistantMessage", "fauxText"]
|
|
4
|
+
"sourcesContent": ["import { InjectionToken, Signal } from 'static-injector';\nimport { OpenAIConfig } from './type';\n\nexport const OpenAIConfigToken = new InjectionToken<Signal<OpenAIConfig>>(\n 'OpenAIConfig',\n);\n", "import * as v from 'valibot';\nexport const ChatCompletionContentPartStr = v.object({\n text: v.string(),\n type: v.optional(v.literal('text'), 'text'),\n});\nexport type ChatCompletionContentPartStrType = v.InferOutput<\n typeof ChatCompletionContentPartStr\n>;\n\nexport const ChatCompletionContentPartImage = v.object({\n image_url: v.object({\n url: v.string(),\n }),\n type: v.optional(v.literal('image_url'), 'image_url'),\n});\nexport type ChatCompletionContentPartImageType = v.InferOutput<\n typeof ChatCompletionContentPartImage\n>;\nexport const ChatCompletionContentPart = v.array(\n v.union([ChatCompletionContentPartStr, ChatCompletionContentPartImage]),\n);\nexport const SystemChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const UserChatCompletionContent = ChatCompletionContentPart;\nexport type UserChatCompletionContentType = v.InferOutput<\n typeof UserChatCompletionContent\n>;\nexport const AssistantChatCompletionContent = v.array(\n ChatCompletionContentPartStr,\n);\nexport const SystemChatMessage = v.object({\n role: v.optional(v.literal('system'), 'system'),\n content: SystemChatCompletionContent,\n});\nexport type SystemChatMessageType = v.InferOutput<typeof SystemChatMessage>;\nexport const UserChatMessage = v.object({\n role: v.optional(v.literal('user'), 'user'),\n content: UserChatCompletionContent,\n});\nexport type UserChatMessageType = v.InferOutput<typeof UserChatMessage>;\n\nexport const AssistantChatMessage = v.object({\n role: v.optional(v.literal('assistant'), 'assistant'),\n content: AssistantChatCompletionContent,\n thinkContent: v.optional(v.string()),\n});\n\nexport type AssistantChatMessageType = v.InferOutput<\n typeof AssistantChatMessage\n>;\n\nexport const ChatMessageItemDefine = v.union([\n SystemChatMessage,\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport const ChatMessageCommonItemDefine = v.union([\n UserChatMessage,\n AssistantChatMessage,\n]);\nexport type ChatMessageItemType = v.InferOutput<typeof ChatMessageItemDefine>;\nexport const ChatMessageListDefine = v.array(ChatMessageItemDefine);\n\nexport type ChatMessageListOutputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\nexport type ChatMessageListInputType = v.InferOutput<\n typeof ChatMessageListDefine\n>;\n", "import {\n AssistantChatMessageType,\n SystemChatMessageType,\n UserChatMessageType,\n} from '../message.define';\n\nexport function createSystemMessage() {\n return { role: 'system' } as SystemChatMessageType;\n}\nexport function createUserMessage(text?: string) {\n return {\n role: 'user',\n content:\n typeof text === 'string' ? [{ type: 'text', text: '' }] : undefined,\n } as UserChatMessageType;\n}\nexport function createAssistantMessage(text: string = '') {\n return {\n role: 'assistant',\n content: [{ type: 'text', text }],\n } as AssistantChatMessageType;\n}\n", "import { OpenAIConfigToken } from './token';\n\nexport const OPENAI_MODULE = {\n provider: [],\n token: { OpenAIConfigToken },\n};\n", "import {\n AssistantMessage,\n Context,\n stream,\n StreamOptions,\n UserMessage,\n} from '@earendil-works/pi-ai';\nimport {\n getModelConfig,\n ModelConfigInputType,\n} from './util/get-custom-provider';\nimport type OpenAI from 'openai';\nimport {\n AssistantChatMessage,\n ChatMessageItemType,\n SystemChatMessageType,\n UserChatMessage,\n} from './message.define';\nimport { deepClone } from '@cyia/util';\nimport { Injector } from 'static-injector';\nimport { OpenAIConfigToken } from './token';\nimport * as v from 'valibot';\n\nexport function createChatStream(input: ModelConfigInputType) {\n const result = getModelConfig(input);\n return (\n context: Omit<Context, 'messages'> & { messages: ChatMessageItemType[] },\n options?: StreamOptions,\n extra?: {\n response_format?: OpenAI.Chat.Completions.ChatCompletionCreateParamsStreaming['response_format'];\n injector?: Injector;\n },\n ) => {\n context.messages = deepClone(context.messages);\n const PiPUserConvertDefine = v.pipe(\n UserChatMessage,\n v.transform(\n (item) =>\n ({\n role: 'user',\n timestamp: Date.now(),\n content: item.content.map((item) => {\n if (item.type === 'text') {\n return item;\n } else {\n const match = item.image_url.url.match(\n /^data:([^;]+);base64,(.+)$/,\n );\n return {\n type: 'image',\n mimeType: match![1],\n data: match![2],\n };\n }\n }),\n }) satisfies UserMessage,\n ),\n );\n const PiPAssConvertDefine = v.pipe(\n AssistantChatMessage,\n v.transform(\n (item) =>\n ({\n role: 'assistant',\n timestamp: Date.now(),\n content: item.content.map((item) => item),\n api: result.model.api,\n provider: result.model.provider,\n usage: {\n cacheRead: 0,\n cacheWrite: 0,\n cost: {\n input: 0,\n output: 0,\n cacheRead: 0,\n cacheWrite: 0,\n total: 0,\n },\n input: 0,\n output: 0,\n totalTokens: 0,\n },\n stopReason: 'stop',\n model: result.model.api,\n }) satisfies AssistantMessage,\n ),\n );\n // todo 系统类型在输入时未处理\n const sysIndex = context.messages.findIndex(\n (item) => item.role === 'system',\n );\n if (sysIndex !== -1) {\n const item = context.messages[sysIndex] as any as SystemChatMessageType;\n context.messages.splice(sysIndex, 1);\n context.systemPrompt = item.content[0].text;\n }\n const createStream = () =>\n stream(\n result.model,\n {\n ...context,\n messages: v.parse(\n v.array(v.union([PiPUserConvertDefine, PiPAssConvertDefine])),\n context.messages,\n ),\n },\n {\n ...options,\n\n apiKey: options?.apiKey ?? result.config.apiKey,\n onPayload(payload, model) {\n payload = options?.onPayload?.(payload, model) ?? payload;\n if (model.api === 'openai-completions') {\n return {\n ...(payload as any),\n response_format: extra?.response_format,\n };\n }\n return payload;\n },\n },\n );\n\n let currentStream = createStream();\n const config = extra?.injector?.get(OpenAIConfigToken);\n return (async function* () {\n let hasRetry = false;\n while (true) {\n let retry = false;\n for await (const item of currentStream) {\n if (item.type === 'error') {\n if (\n item.error.errorMessage?.includes('404') &&\n item.error.errorMessage?.includes(\n 'no router for requested model',\n ) &&\n !hasRetry\n ) {\n if (config?.().tryPull?.()) {\n await config().pullModel?.(input.model);\n retry = true;\n break;\n }\n }\n }\n yield item;\n }\n if (!retry || hasRetry) {\n break;\n }\n hasRetry = true;\n currentStream = createStream();\n }\n })();\n };\n}\n", "import * as v from 'valibot';\n\nimport { getModel, Model } from '@earendil-works/pi-ai';\nimport { KnownProviderDefine } from '../provider.define';\nimport { hideWhen } from '@piying/view-angular-core';\nimport { map } from 'rxjs';\n\nfunction getCustomProvider<\n T extends 'openai-completions' | 'openai-responses' | 'anthropic-messages',\n>(\n compat: T,\n model: string,\n name: string,\n input: Omit<Model<T>, 'api' | 'id' | 'name'>,\n) {\n return { ...input, id: model, api: compat, name } satisfies Model<T>;\n}\nexport function getModelConfig(input: ModelConfigInputType) {\n if (input.provider === ('faux' as any)) {\n return {\n model: input.config as Model<any>,\n config: input as ModelConfigOutputType,\n };\n }\n const config = v.parse(ModelConfigDefine, input);\n if (\n config.provider === 'openai-completions' ||\n config.provider === 'openai-responses' ||\n config.provider === 'anthropic-messages'\n ) {\n return {\n model: getCustomProvider(\n config.provider,\n config.model,\n config.name,\n config.config!,\n ),\n config: config,\n };\n }\n\n return {\n model: getModel(config.provider, config.model as any as never),\n config: config,\n };\n}\nexport const ThinkingLevelSchema = v.pipe(\n v.picklist(['minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('思考等级'),\n v.description('模型思考的详细程度,从最小到最大'),\n);\n\nexport const ModelThinkingLevelSchema = v.pipe(\n v.picklist(['off', 'minimal', 'low', 'medium', 'high', 'xhigh']),\n v.title('模型思考等级'),\n v.description('关闭或设置模型思考的详细程度'),\n);\n\n// --- Compat schemas (conditional on TApi) ---\n\n/** OpenAI Completions compatibility overrides */\nexport const OpenAICompletionsCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsStore: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持存储'),\n v.description('是否支持服务端会话存储'),\n ),\n ),\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n supportsReasoningEffort: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持推理努力'),\n v.description('是否支持 reasoning_effort 参数'),\n ),\n ),\n supportsUsageInStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title('流式用量'),\n v.description('流式输出中是否返回 usage 信息'),\n ),\n ),\n maxTokensField: v.optional(\n v.pipe(\n v.picklist(['max_completion_tokens', 'max_tokens']),\n v.title('最大 token 字段名'),\n v.description('指定最大 token 参数使用的是哪个字段名'),\n ),\n ),\n requiresToolResultName: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要工具结果名称'),\n v.description('是否要求工具结果消息包含 name 字段'),\n ),\n ),\n requiresAssistantAfterToolResult: v.optional(\n v.pipe(\n v.boolean(),\n v.title('需要助手回复'),\n v.description('工具结果后是否需要助手消息跟进'),\n ),\n ),\n requiresThinkingAsText: v.optional(\n v.pipe(\n v.boolean(),\n v.title('思考转文本'),\n v.description('是否将思考过程作为普通文本发送'),\n ),\n ),\n requiresReasoningContentOnAssistantMessages: v.optional(\n v.pipe(\n v.boolean(),\n v.title('推理内容在助手消息中'),\n v.description('是否在助手消息中包含推理内容'),\n ),\n ),\n thinkingFormat: v.optional(\n v.pipe(\n v.picklist([\n 'openai',\n 'openrouter',\n 'deepseek',\n 'together',\n 'zai',\n 'qwen',\n 'qwen-chat-template',\n 'string-thinking',\n 'ant-ling',\n ]),\n v.title('思考格式'),\n v.description('指定 thinking 标签的序列化格式'),\n ),\n ),\n openRouterRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('OpenRouter 路由'),\n v.description('自定义 OpenRouter 的路由配置'),\n ),\n ),\n vercelGatewayRouting: v.optional(\n v.pipe(\n v.unknown(),\n v.title('Vercel Gateway 路由'),\n v.description('自定义 Vercel AI Gateway 的路由配置'),\n ),\n ),\n zaiToolStream: v.optional(\n v.pipe(\n v.boolean(),\n v.title('ZAI 工具流式'),\n v.description('是否启用 ZAI 平台工具调用的流式输出'),\n ),\n ),\n supportsStrictMode: v.optional(\n v.pipe(\n v.boolean(),\n v.title('严格模式'),\n v.description('是否支持工具的 JSON Schema 严格校验'),\n ),\n ),\n cacheControlFormat: v.optional(\n v.pipe(\n v.literal('anthropic'),\n v.title('缓存控制格式'),\n v.description('指定缓存控制的语法格式'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Completions 兼容配置'),\n v.description('针对 OpenAI Completions API 的兼容性覆写选项'),\n);\n\n/** OpenAI Responses compatibility overrides */\nexport const OpenAIResponsesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsDeveloperRole: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持开发者角色'),\n v.description('是否支持 developer 系统消息角色'),\n ),\n ),\n sendSessionIdHeader: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话 ID 标头'),\n v.description('是否在请求中携带 X-Session-ID 标头'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n }),\n ),\n v.title('OpenAI Responses 兼容配置'),\n v.description('针对 OpenAI Responses API 的兼容性覆写选项'),\n);\n\n/** Anthropic Messages compatibility overrides */\nexport const AnthropicMessagesCompatSchema = v.pipe(\n v.optional(\n v.object({\n supportsEagerToolInputStreaming: v.optional(\n v.pipe(\n v.boolean(),\n v.title(' eagerly 工具流式'),\n v.description('是否支持工具调用的 eager 模式流式输出'),\n ),\n ),\n supportsLongCacheRetention: v.optional(\n v.pipe(\n v.boolean(),\n v.title('长期缓存保留'),\n v.description('是否支持长期缓存保留策略'),\n ),\n ),\n sendSessionAffinityHeaders: v.optional(\n v.pipe(\n v.boolean(),\n v.title('发送会话亲和标头'),\n v.description('是否在请求中携带会话亲和性标头'),\n ),\n ),\n supportsCacheControlOnTools: v.optional(\n v.pipe(\n v.boolean(),\n v.title('工具缓存控制'),\n v.description('是否支持在 tool_use 消息中使用 cache_control'),\n ),\n ),\n supportsTemperature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('支持温度参数'),\n v.description('模型/接口是否支持 temperature 参数'),\n ),\n ),\n forceAdaptiveThinking: v.optional(\n v.pipe(\n v.boolean(),\n v.title('强制自适应思考'),\n v.description('是否强制启用 adaptive thinking 模式'),\n ),\n ),\n allowEmptySignature: v.optional(\n v.pipe(\n v.boolean(),\n v.title('允许空签名'),\n v.description('是否允许工具调用不指定签名(sha256)'),\n ),\n ),\n }),\n ),\n v.title('Anthropic Messages 兼容配置'),\n v.description('针对 Anthropic Messages API 的兼容性覆写选项'),\n);\n\n// Generic compat schema (union of all compat types)\nexport const CompatSchema = v.pipe(\n v.union([\n OpenAICompletionsCompatSchema,\n OpenAIResponsesCompatSchema,\n AnthropicMessagesCompatSchema,\n ]),\n v.title('兼容配置'),\n v.description(\n '模型 API 兼容性覆写选项,支持 OpenAI Completions、OpenAI Responses、Anthropic Messages 三种格式',\n ),\n);\n\n// --- Input array: (\"text\" | \"image\")[] ---\n\nexport const InputChoiceSchema = v.pipe(\n v.picklist(['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n);\nexport const InputSchema = v.pipe(\n v.array(InputChoiceSchema),\n v.title('输入类型列表'),\n v.description('该模型支持的用户输入类型,如 text 文本或 image 图片'),\n);\n\n// --- Headers: Record<string, string> ---\n\nconst HeadersSchema = v.pipe(\n v.record(v.string(), v.string()),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头键值对配置'),\n);\n\n// --- Model schema (non-generic) ---\n\n/** Cost sub-schema */\nconst CostSchema = v.pipe(\n v.optional(\n v.object({\n input: v.pipe(\n v.number(),\n v.title('输入单价'),\n v.description('每 token 输入费用'),\n ),\n output: v.pipe(\n v.number(),\n v.title('输出单价'),\n v.description('每 token 输出费用'),\n ),\n cacheRead: v.pipe(\n v.number(),\n v.title('缓存读取单价'),\n v.description('从缓存读取每 token 的费用'),\n ),\n cacheWrite: v.pipe(\n v.number(),\n v.title('缓存写入单价'),\n v.description('写入缓存每 token 的费用'),\n ),\n }),\n { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },\n ),\n v.title('费用配置'),\n v.description('模型各操作类型的 token 计价标准'),\n);\n\n/** Thinking level map: Partial<Record<ModelThinkingLevel, string | null>> */\nconst ThinkingLevelMapSchema = v.pipe(\n v.record(\n ModelThinkingLevelSchema,\n v.pipe(\n v.nullish(v.string()),\n v.title('配置值'),\n v.description('对应思考等级的具体配置字符串,null 表示未设置'),\n ),\n ),\n v.title('思考等级配置映射'),\n v.description('各思考等级对应的具体配置参数映射'),\n);\n\n/**\n * Model schema for pi-ai models.\n * Matches `Model<TApi extends Api>` but without generic type preservation\n * at runtime — compat accepts any of the three compat variants via union.\n */\nexport const ModelSchema = v.pipe(\n v.object({\n provider: v.pipe(\n v.optional(v.string(), 'default'),\n v.title('厂商'),\n v.description('模型提供商,如 openai / anthropic / llama'),\n ),\n baseUrl: v.pipe(\n v.string(),\n v.title('基础 URL'),\n v.description('API 请求的基础地址'),\n ),\n reasoning: v.pipe(\n v.optional(v.boolean(), false),\n v.title('支持推理'),\n v.description('该模型是否支持思考/推理模式'),\n ),\n // thinkingLevelMap: v.optional(\n // v.pipe(\n // v.optional(ThinkingLevelMapSchema),\n // v.title('思考等级配置'),\n // v.description('各思考等级的具体参数配置映射'),\n // ),\n // ),\n input: v.pipe(\n v.optional(InputSchema, ['text', 'image']),\n v.title('输入类型'),\n v.description('支持的输入模态类型'),\n ),\n cost: v.pipe(\n CostSchema,\n v.title('费用配置'),\n v.description('模型 token 计价标准'),\n ),\n contextWindow: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('上下文窗口'),\n v.description('模型支持的上下文最大 token 数'),\n ),\n maxTokens: v.pipe(\n v.pipe(v.optional(v.number(), 99999999)),\n v.title('最大输出 tokens'),\n v.description('单次请求允许的最大输出 token 数'),\n ),\n headers: v.optional(\n v.pipe(\n v.optional(HeadersSchema),\n v.title('自定义请求头'),\n v.description('额外的 HTTP 请求头配置'),\n ),\n ),\n compat: v.pipe(\n v.optional(CompatSchema, { supportsDeveloperRole: false }),\n v.title('兼容配置'),\n v.description('API 兼容性覆写选项'),\n ),\n }),\n v.title('模型定义'),\n v.description(\n 'pi-ai 模型的核心配置结构,包含模型标识、API 参数、费用及兼容性设置',\n ),\n);\n\nexport type ModelInput = v.InferInput<typeof ModelSchema>;\nexport type ModelOutput = v.InferOutput<typeof ModelSchema>;\n\n// --- ImagesModel schema ---\n\n/** Output array for image models: (\"text\" | \"image\")[] */\nexport const OutputSchema = InputSchema; // same structure\n\nexport const ModelConfigDefine = v.pipe(\n v.object({\n provider: KnownProviderDefine,\n model: v.pipe(v.string(), v.title('模型名')),\n name: v.pipe(\n v.optional(v.string()),\n v.title('配置名'),\n v.description('模型的配置名称(默认为模型名)'),\n ),\n /** provider是自定义时使用 */\n apiKey: v.pipe(v.optional(v.string()), v.title('apiKey')),\n config: v.pipe(\n v.optional(ModelSchema),\n hideWhen({\n disabled: true,\n listen(fn, field) {\n return fn({ list: [['..', 'provider']] }).pipe(\n map(\n ({ list: [value] }) =>\n !(\n value === 'openai-completions' ||\n value === 'openai-responses' ||\n value === 'anthropic-messages'\n ),\n ),\n );\n },\n }),\n ),\n }),\n v.transform((item) => ({ ...item, name: item.name ?? item.model })),\n);\n\nexport type ModelConfigInputType = v.InferInput<typeof ModelConfigDefine>;\nexport type ModelConfigOutputType = v.InferOutput<typeof ModelConfigDefine>;\n", "import * as v from 'valibot';\nimport { KnownProvider } from '@earendil-works/pi-ai';\nexport const KnownProviderDefine = v.pipe(\n v.picklist([\n 'amazon-bedrock',\n 'anthropic',\n 'google',\n 'google-vertex',\n 'openai',\n 'azure-openai-responses',\n 'openai-codex',\n 'deepseek',\n 'github-copilot',\n 'xai',\n 'groq',\n 'cerebras',\n 'openrouter',\n 'vercel-ai-gateway',\n 'zai',\n 'mistral',\n 'minimax',\n 'minimax-cn',\n 'moonshotai',\n 'moonshotai-cn',\n 'huggingface',\n 'fireworks',\n 'together',\n 'opencode',\n 'opencode-go',\n 'kimi-coding',\n 'cloudflare-workers-ai',\n 'cloudflare-ai-gateway',\n 'xiaomi',\n 'xiaomi-token-plan-cn',\n 'xiaomi-token-plan-ams',\n 'xiaomi-token-plan-sgp',\n 'ant-ling',\n 'nvidia',\n 'zai-coding-cn',\n /** 自定义 */\n 'openai-completions',\n 'openai-responses',\n 'anthropic-messages',\n ]),\n v.title('提供商'),\n v.description(`'openai-completions','openai-responses','anthropic-messages',为自定义提供商`),\n);\n\nexport type KnownProviderType = v.InferOutput<typeof KnownProviderDefine>;\ntype D2T = KnownProvider extends KnownProviderType ? true : false;\ntype T2D = KnownProviderType extends KnownProvider ? true : false;\n", "export * from './chat/token';\nexport * from './chat/message.define';\nexport * from './chat/util/create';\nexport * from './chat/type/history';\nexport * from './chat/type';\nexport * from './chat/module';\nexport * from './chat/chat'\nexport * from './chat/util/get-custom-provider'\nexport { complete, stream, fauxAssistantMessage, fauxText, fauxThinking } from '@earendil-works/pi-ai'\nexport * from './chat/util/faux-provider'", "import {\n registerFauxProvider,\n fauxAssistantMessage,\n fauxText,\n Context,\n StreamOptions,\n FauxResponseStep,\n} from '@earendil-works/pi-ai';\n\n/**\n * 创建一个基于用户输入动态返回响应的方法。\n * @param responseFactory - 根据上下文动态生成响应的工厂函数,接收历史消息和调用序号,返回文本或文本数组\n */\nexport function createDynamicResponse(\n responseFactory: (context: Context, callCount: number) => string | string[],\n) {\n return async (\n context: Context,\n _options: StreamOptions | undefined,\n state: { callCount: number },\n ) => {\n const responses = responseFactory(context, state.callCount);\n const content = Array.isArray(responses)\n ? responses.map((r) => fauxText(r))\n : fauxText(responses);\n return fauxAssistantMessage(content);\n };\n}\n\n/** Options for registerFauxProvider. */\nexport interface MockProviderOptions {\n api?: string;\n provider?: string;\n tokensPerSecond?: number;\n}\n\n\n\n/**\n * Register a faux mock provider and return a ready-to-use model with cleanup.\n * \n * @example\n * ```ts\n * const { model, setResponses, unregister } = registerMockProvider();\n * setResponses([fauxAssistantMessage('hello')]);\n * const response = await complete(model, { messages: [{ role: 'user', content: 'hi', timestamp: Date.now() }] });\n * unregister(); // clean up when done\n * ```\n */\nexport function registerMockProvider(\n options?: MockProviderOptions,\n) {\n const registration = registerFauxProvider(options);\n\n return {\n model: registration.getModel(),\n setResponses: (responses: FauxResponseStep[]) => registration.setResponses(responses),\n unregister: () => registration.unregister(),\n };\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["v", "v", "v", "item", "stream", "fauxAssistantMessage", "fauxText"]
|
|
7
7
|
}
|