@ailib-official/ai-protocol 0.8.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.
Files changed (194) hide show
  1. package/LICENSE +6 -0
  2. package/README.md +415 -0
  3. package/dist/index.json +8 -0
  4. package/dist/v1/models/ai21.json +140 -0
  5. package/dist/v1/models/baichuan.json +138 -0
  6. package/dist/v1/models/cerebras.json +147 -0
  7. package/dist/v1/models/claude.json +114 -0
  8. package/dist/v1/models/cohere.json +235 -0
  9. package/dist/v1/models/deepinfra.json +43 -0
  10. package/dist/v1/models/deepseek-chat.json +55 -0
  11. package/dist/v1/models/doubao.json +197 -0
  12. package/dist/v1/models/ernie.json +223 -0
  13. package/dist/v1/models/fireworks.json +222 -0
  14. package/dist/v1/models/gemini.json +58 -0
  15. package/dist/v1/models/gpt.json +166 -0
  16. package/dist/v1/models/grok.json +138 -0
  17. package/dist/v1/models/huggingface.json +183 -0
  18. package/dist/v1/models/hunyuan.json +255 -0
  19. package/dist/v1/models/jina.json +139 -0
  20. package/dist/v1/models/lepton.json +188 -0
  21. package/dist/v1/models/llama.json +143 -0
  22. package/dist/v1/models/minimax.json +194 -0
  23. package/dist/v1/models/mistral.json +177 -0
  24. package/dist/v1/models/moonshot.json +144 -0
  25. package/dist/v1/models/nvidia.json +212 -0
  26. package/dist/v1/models/palmyra.json +103 -0
  27. package/dist/v1/models/perplexity.json +143 -0
  28. package/dist/v1/models/qwen.json +49 -0
  29. package/dist/v1/models/replicate.json +206 -0
  30. package/dist/v1/models/sensenova.json +144 -0
  31. package/dist/v1/models/siliconflow.json +44 -0
  32. package/dist/v1/models/spark.json +173 -0
  33. package/dist/v1/models/stable-diffusion.json +161 -0
  34. package/dist/v1/models/tiangong.json +169 -0
  35. package/dist/v1/models/together.json +43 -0
  36. package/dist/v1/models/yi.json +199 -0
  37. package/dist/v1/models/zhipu.json +250 -0
  38. package/dist/v1/providers/ai21.json +215 -0
  39. package/dist/v1/providers/anthropic.json +253 -0
  40. package/dist/v1/providers/anyscale.json +115 -0
  41. package/dist/v1/providers/azure.json +188 -0
  42. package/dist/v1/providers/baichuan.json +205 -0
  43. package/dist/v1/providers/baidu.json +205 -0
  44. package/dist/v1/providers/cerebras.json +216 -0
  45. package/dist/v1/providers/cohere.json +209 -0
  46. package/dist/v1/providers/deepinfra.json +196 -0
  47. package/dist/v1/providers/deepseek.json +221 -0
  48. package/dist/v1/providers/doubao.json +209 -0
  49. package/dist/v1/providers/fireworks.json +227 -0
  50. package/dist/v1/providers/gemini.json +279 -0
  51. package/dist/v1/providers/groq.json +218 -0
  52. package/dist/v1/providers/huggingface.json +181 -0
  53. package/dist/v1/providers/hunyuan.json +198 -0
  54. package/dist/v1/providers/jina.json +202 -0
  55. package/dist/v1/providers/lepton.json +221 -0
  56. package/dist/v1/providers/minimax.json +209 -0
  57. package/dist/v1/providers/mistral.json +214 -0
  58. package/dist/v1/providers/moonshot.json +214 -0
  59. package/dist/v1/providers/nvidia.json +213 -0
  60. package/dist/v1/providers/openai.json +267 -0
  61. package/dist/v1/providers/openrouter.json +220 -0
  62. package/dist/v1/providers/perplexity.json +172 -0
  63. package/dist/v1/providers/qwen.json +231 -0
  64. package/dist/v1/providers/replicate.json +192 -0
  65. package/dist/v1/providers/sensenova.json +185 -0
  66. package/dist/v1/providers/siliconflow.json +197 -0
  67. package/dist/v1/providers/spark.json +204 -0
  68. package/dist/v1/providers/stability.json +221 -0
  69. package/dist/v1/providers/tiangong.json +207 -0
  70. package/dist/v1/providers/together.json +196 -0
  71. package/dist/v1/providers/writer.json +253 -0
  72. package/dist/v1/providers/xai.json +238 -0
  73. package/dist/v1/providers/yi.json +205 -0
  74. package/dist/v1/providers/zhipu.json +208 -0
  75. package/dist/v1/spec.json +783 -0
  76. package/dist/v2/providers/anthropic.json +372 -0
  77. package/dist/v2/providers/cohere.json +109 -0
  78. package/dist/v2/providers/deepseek.json +272 -0
  79. package/dist/v2/providers/doubao.json +260 -0
  80. package/dist/v2/providers/google.json +388 -0
  81. package/dist/v2/providers/jina.json +71 -0
  82. package/dist/v2/providers/moonshot.json +284 -0
  83. package/dist/v2/providers/openai.json +419 -0
  84. package/dist/v2/providers/qwen.json +274 -0
  85. package/dist/v2/providers/zhipu.json +257 -0
  86. package/dist/v2-alpha/providers/anthropic.json +182 -0
  87. package/dist/v2-alpha/providers/gemini.json +187 -0
  88. package/dist/v2-alpha/providers/openai.json +215 -0
  89. package/dist/v2-alpha/spec.json +644 -0
  90. package/package.json +61 -0
  91. package/schemas/spec.json +186 -0
  92. package/schemas/v1.json +1116 -0
  93. package/schemas/v2/availability.json +66 -0
  94. package/schemas/v2/capabilities.json +182 -0
  95. package/schemas/v2/capability-profile.json +174 -0
  96. package/schemas/v2/computer-use.json +222 -0
  97. package/schemas/v2/context-policy.json +148 -0
  98. package/schemas/v2/endpoint.json +2 -0
  99. package/schemas/v2/error-codes.yaml +225 -0
  100. package/schemas/v2/errors.json +250 -0
  101. package/schemas/v2/execution-metadata.json +59 -0
  102. package/schemas/v2/mcp.json +225 -0
  103. package/schemas/v2/message-roles.json +10 -0
  104. package/schemas/v2/multimodal.json +297 -0
  105. package/schemas/v2/pricing.json +14 -0
  106. package/schemas/v2/provider-contract.json +317 -0
  107. package/schemas/v2/provider.json +203 -0
  108. package/schemas/v2/regions.json +14 -0
  109. package/v1/models/ai21.yaml +97 -0
  110. package/v1/models/baichuan.yaml +95 -0
  111. package/v1/models/cerebras.yaml +99 -0
  112. package/v1/models/claude.yaml +59 -0
  113. package/v1/models/cohere.yaml +165 -0
  114. package/v1/models/deepinfra.yaml +29 -0
  115. package/v1/models/deepseek-chat.yaml +32 -0
  116. package/v1/models/doubao.yaml +129 -0
  117. package/v1/models/ernie.yaml +146 -0
  118. package/v1/models/fireworks.yaml +145 -0
  119. package/v1/models/gemini.yaml +32 -0
  120. package/v1/models/gpt.yaml +90 -0
  121. package/v1/models/grok.yaml +74 -0
  122. package/v1/models/huggingface.yaml +110 -0
  123. package/v1/models/hunyuan.yaml +164 -0
  124. package/v1/models/jina.yaml +98 -0
  125. package/v1/models/lepton.yaml +130 -0
  126. package/v1/models/llama.yaml +91 -0
  127. package/v1/models/minimax.yaml +132 -0
  128. package/v1/models/mistral.yaml +100 -0
  129. package/v1/models/moonshot.yaml +97 -0
  130. package/v1/models/nvidia.yaml +118 -0
  131. package/v1/models/palmyra.yaml +59 -0
  132. package/v1/models/perplexity.yaml +97 -0
  133. package/v1/models/qwen.yaml +27 -0
  134. package/v1/models/replicate.yaml +136 -0
  135. package/v1/models/sensenova.yaml +97 -0
  136. package/v1/models/siliconflow.yaml +29 -0
  137. package/v1/models/spark.yaml +114 -0
  138. package/v1/models/stable-diffusion.yaml +113 -0
  139. package/v1/models/tiangong.yaml +114 -0
  140. package/v1/models/together.yaml +29 -0
  141. package/v1/models/yi.yaml +132 -0
  142. package/v1/models/zhipu.yaml +163 -0
  143. package/v1/providers/ai21.yaml +176 -0
  144. package/v1/providers/anthropic.yaml +209 -0
  145. package/v1/providers/anyscale.yaml +106 -0
  146. package/v1/providers/azure.yaml +155 -0
  147. package/v1/providers/baichuan.yaml +168 -0
  148. package/v1/providers/baidu.yaml +173 -0
  149. package/v1/providers/cerebras.yaml +178 -0
  150. package/v1/providers/cohere.yaml +175 -0
  151. package/v1/providers/deepinfra.yaml +156 -0
  152. package/v1/providers/deepseek.yaml +189 -0
  153. package/v1/providers/doubao.yaml +172 -0
  154. package/v1/providers/fireworks.yaml +187 -0
  155. package/v1/providers/gemini.yaml +229 -0
  156. package/v1/providers/groq.yaml +181 -0
  157. package/v1/providers/huggingface.yaml +157 -0
  158. package/v1/providers/hunyuan.yaml +162 -0
  159. package/v1/providers/jina.yaml +171 -0
  160. package/v1/providers/lepton.yaml +183 -0
  161. package/v1/providers/minimax.yaml +172 -0
  162. package/v1/providers/mistral.yaml +186 -0
  163. package/v1/providers/moonshot.yaml +176 -0
  164. package/v1/providers/nvidia.yaml +172 -0
  165. package/v1/providers/openai.yaml +224 -0
  166. package/v1/providers/openrouter.yaml +181 -0
  167. package/v1/providers/perplexity.yaml +144 -0
  168. package/v1/providers/qwen.yaml +192 -0
  169. package/v1/providers/replicate.yaml +159 -0
  170. package/v1/providers/sensenova.yaml +153 -0
  171. package/v1/providers/siliconflow.yaml +156 -0
  172. package/v1/providers/spark.yaml +167 -0
  173. package/v1/providers/stability.yaml +185 -0
  174. package/v1/providers/tiangong.yaml +170 -0
  175. package/v1/providers/together.yaml +156 -0
  176. package/v1/providers/writer.yaml +212 -0
  177. package/v1/providers/xai.yaml +206 -0
  178. package/v1/providers/yi.yaml +168 -0
  179. package/v1/providers/zhipu.yaml +171 -0
  180. package/v1/spec.yaml +637 -0
  181. package/v2/providers/anthropic.yaml +244 -0
  182. package/v2/providers/cohere.yaml +75 -0
  183. package/v2/providers/deepseek.yaml +176 -0
  184. package/v2/providers/doubao.yaml +169 -0
  185. package/v2/providers/google.yaml +245 -0
  186. package/v2/providers/jina.yaml +55 -0
  187. package/v2/providers/moonshot.yaml +186 -0
  188. package/v2/providers/openai.yaml +266 -0
  189. package/v2/providers/qwen.yaml +174 -0
  190. package/v2/providers/zhipu.yaml +176 -0
  191. package/v2-alpha/providers/anthropic.yaml +134 -0
  192. package/v2-alpha/providers/gemini.yaml +144 -0
  193. package/v2-alpha/providers/openai.yaml +154 -0
  194. package/v2-alpha/spec.yaml +512 -0
@@ -0,0 +1,212 @@
1
+ $schema: "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v1.json"
2
+
3
+ id: writer
4
+ protocol_version: "1.5"
5
+
6
+ name: Writer
7
+ version: "v1"
8
+ status: stable
9
+ category: ai_provider
10
+ official_url: "https://dev.writer.com"
11
+ support_contact: "https://writer.com/support"
12
+
13
+ # Structured endpoint definition (v1.1+ extension)
14
+ endpoint:
15
+ base_url: "https://api.writer.com"
16
+ protocol: https
17
+ timeout_ms: 10000
18
+
19
+ auth:
20
+ type: bearer
21
+ token_env: "WRITER_API_KEY"
22
+ payload_format: "openai_style"
23
+
24
+ # Writer provides Palmyra models optimized for enterprise use
25
+ api_families: ["chat_completions", "completions"]
26
+ default_api_family: "chat_completions"
27
+ endpoints:
28
+ chat:
29
+ path: "/v1/chat/completions"
30
+ method: "POST"
31
+ adapter: "openai"
32
+ completions:
33
+ path: "/v1/completions"
34
+ method: "POST"
35
+ adapter: "openai"
36
+ embeddings:
37
+ path: "/v1/embeddings"
38
+ method: "POST"
39
+ adapter: "openai"
40
+
41
+ # V1.5 Service Endpoints
42
+ services:
43
+ list_models:
44
+ path: "/v1/models"
45
+ method: "GET"
46
+ response_binding: "data"
47
+
48
+ # Termination reason normalization
49
+ termination:
50
+ source_field: "finish_reason"
51
+ mapping:
52
+ stop: "end_turn"
53
+ length: "max_tokens"
54
+ tool_calls: "tool_use"
55
+ content_filter: "refusal"
56
+ notes:
57
+ - "Follows OpenAI finish_reason semantics"
58
+ - "finish_reason is reported per candidate"
59
+
60
+ # Tool invocation normalization
61
+ tooling:
62
+ source_model: "openai_tool_calls"
63
+ tool_use:
64
+ id_path: "id"
65
+ name_path: "function.name"
66
+ input_path: "function.arguments"
67
+ input_format: "json_string"
68
+ notes:
69
+ - "Writer follows OpenAI tool calling conventions"
70
+ - "tool_calls.function.arguments is a JSON string"
71
+
72
+ # Rate limits
73
+ rate_limit_headers:
74
+ requests_limit: "x-ratelimit-limit-requests"
75
+ requests_remaining: "x-ratelimit-remaining-requests"
76
+ requests_reset: "x-ratelimit-reset-requests"
77
+
78
+ # Retry policy
79
+ retry_policy:
80
+ strategy: "exponential_backoff"
81
+ max_retries: 3
82
+ max_delay_ms: 30000
83
+ min_delay_ms: 1000
84
+ jitter: "full"
85
+ retry_on_http_status: [429, 500, 502, 503]
86
+ notes:
87
+ - "Follows OpenAI retry guidance"
88
+ - "Exponential backoff for rate limits and server errors"
89
+
90
+ # Error classification hints
91
+ error_classification:
92
+ by_http_status:
93
+ "400": "invalid_request"
94
+ "401": "authentication"
95
+ "403": "permission_denied"
96
+ "404": "not_found"
97
+ "429": "rate_limited"
98
+ "500": "server_error"
99
+ notes:
100
+ - "Follows OpenAI error classification"
101
+ - "429 may indicate rate limit or quota exhaustion"
102
+
103
+ parameter_mappings:
104
+ temperature: "temperature"
105
+ max_tokens: "max_tokens"
106
+ stream: "stream"
107
+ top_p: "top_p"
108
+ stop_sequences: "stop"
109
+ frequency_penalty: "frequency_penalty"
110
+ presence_penalty: "presence_penalty"
111
+ logprobs: "logprobs"
112
+ top_logprobs: "top_logprobs"
113
+ seed: "seed"
114
+ tools: "tools"
115
+ tool_choice: "tool_choice"
116
+
117
+ response_format: "openai_style"
118
+ response_paths:
119
+ content: "choices[0].message.content"
120
+ tool_calls: "choices[0].message.tool_calls"
121
+ usage: "usage"
122
+ finish_reason: "choices[0].finish_reason"
123
+
124
+ streaming:
125
+ event_format: "data_lines"
126
+ decoder:
127
+ format: "sse"
128
+ delimiter: "\n\n"
129
+ prefix: "data: "
130
+ done_signal: "[DONE]"
131
+ frame_selector: "exists($.choices) || exists($.error) || $.type == 'error'"
132
+ candidate:
133
+ candidate_id_path: "$.choices[*].index"
134
+ fan_out: true
135
+ event_map:
136
+ - match: "exists($.error) || $.type == 'error'"
137
+ emit: "StreamError"
138
+ fields:
139
+ type: "$.type"
140
+ event_id: "$.event_id"
141
+ error: "$.error"
142
+ - match: "exists($.choices[*].delta.content)"
143
+ emit: "PartialContentDelta"
144
+ fields:
145
+ content: "$.choices[*].delta.content"
146
+ - match: "exists($.choices[*].delta.tool_calls[*].function.name)"
147
+ emit: "ToolCallStarted"
148
+ fields:
149
+ tool_call_id: "$.choices[*].delta.tool_calls[*].id"
150
+ tool_name: "$.choices[*].delta.tool_calls[*].function.name"
151
+ index: "$.choices[*].delta.tool_calls[*].index"
152
+ - match: "exists($.choices[*].delta.tool_calls[*].function.arguments)"
153
+ emit: "PartialToolCall"
154
+ fields:
155
+ arguments: "$.choices[*].delta.tool_calls[*].function.arguments"
156
+ index: "$.choices[*].delta.tool_calls[*].index"
157
+ - match: "exists($.usage)"
158
+ emit: "Metadata"
159
+ fields:
160
+ usage: "$.usage"
161
+ prompt_tokens: "$.usage.prompt_tokens"
162
+ completion_tokens: "$.usage.completion_tokens"
163
+ - match: "exists($.choices[*].finish_reason)"
164
+ emit: "FinalCandidate"
165
+ fields:
166
+ finish_reason: "$.choices[*].finish_reason"
167
+ candidate_index: "$.choices[*].index"
168
+ stop_condition: "$.choices[0].finish_reason != null"
169
+ extra_metadata_path: "$.usage"
170
+ content_path: "choices[0].delta.content"
171
+ tool_call_path: "choices[0].delta.tool_calls"
172
+
173
+ features:
174
+ multi_candidate:
175
+ support_type: "native"
176
+ param_name: "n"
177
+ response_mapping:
178
+ tool_calls:
179
+ path: "choices[0].message.tool_calls"
180
+ fields:
181
+ id: "id"
182
+ name: "function.name"
183
+ args: "function.arguments"
184
+ error:
185
+ message_path: "error.message"
186
+ code_path: "error.code"
187
+ type_path: "error.type"
188
+ param_path: "error.param"
189
+
190
+ capabilities:
191
+ streaming: true
192
+ tools: true
193
+ vision: false
194
+ agentic: true
195
+ parallel_tools: false
196
+ reasoning: false
197
+
198
+ experimental_features:
199
+ - "strict_tools"
200
+ - "enterprise_compliance"
201
+ - "factual_accuracy"
202
+
203
+ # Availability and health checking (v1.1+ extension)
204
+ availability:
205
+ required: false
206
+ regions:
207
+ - global
208
+ check:
209
+ method: GET
210
+ path: "/v1/models"
211
+ expected_status: [200, 401]
212
+ timeout_ms: 3000
@@ -0,0 +1,206 @@
1
+ $schema: "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v1.json"
2
+
3
+ id: xai
4
+ protocol_version: "1.5"
5
+
6
+ name: xAI
7
+ version: "v1"
8
+ status: stable
9
+ category: ai_provider
10
+ official_url: "https://docs.x.ai"
11
+ support_contact: "https://x.ai/support"
12
+
13
+ # Structured endpoint definition (v1.1+ extension)
14
+ endpoint:
15
+ base_url: "https://api.x.ai/v1"
16
+ protocol: https
17
+ timeout_ms: 10000
18
+
19
+ auth:
20
+ type: bearer
21
+ token_env: "XAI_API_KEY"
22
+ payload_format: "openai_style"
23
+
24
+ # xAI is OpenAI-compatible, supporting standard chat completions API
25
+ api_families: ["chat_completions"]
26
+ default_api_family: "chat_completions"
27
+ endpoints:
28
+ chat:
29
+ path: "/chat/completions"
30
+ method: "POST"
31
+ adapter: "openai"
32
+
33
+ # V1.5 Service Endpoints
34
+ services:
35
+ list_models:
36
+ path: "/models"
37
+ method: "GET"
38
+ response_binding: "data"
39
+
40
+ # Termination reason normalization (see v1/spec.yaml: standard_schema.streaming_events.termination_reasons)
41
+ termination:
42
+ source_field: "finish_reason"
43
+ mapping:
44
+ stop: "end_turn"
45
+ length: "max_tokens"
46
+ tool_calls: "tool_use"
47
+ content_filter: "refusal"
48
+ notes:
49
+ - "follows OpenAI finish_reason semantics"
50
+ - "finish_reason is reported per candidate"
51
+
52
+ # Tool invocation normalization (see v1/spec.yaml: standard_schema.content_blocks)
53
+ tooling:
54
+ source_model: "openai_tool_calls"
55
+ tool_use:
56
+ id_path: "id"
57
+ name_path: "function.name"
58
+ input_path: "function.arguments"
59
+ input_format: "json_string"
60
+ notes:
61
+ - "xAI tool_calls.function.arguments is a JSON string; runtimes SHOULD parse it into an object"
62
+ - "Follows OpenAI tool calling conventions"
63
+
64
+ # Retry policy
65
+ retry_policy:
66
+ max_retries: 3
67
+ max_delay_ms: 30000
68
+ strategy: "exponential_backoff"
69
+ min_delay_ms: 1000
70
+ jitter: "full"
71
+ retry_on_http_status: [429, 500, 502, 503]
72
+ notes:
73
+ - "Follows OpenAI retry guidance"
74
+ - "exponential backoff recommended for rate limit and server errors"
75
+
76
+ # Error classification hints (see v1/spec.yaml: standard_schema.error_handling.error_classes)
77
+ error_classification:
78
+ by_http_status:
79
+ "400": "invalid_request"
80
+ "401": "authentication"
81
+ "403": "permission_denied"
82
+ "404": "not_found"
83
+ "429": "rate_limited"
84
+ "500": "server_error"
85
+ notes:
86
+ - "Follows OpenAI error classification"
87
+ - "429 may indicate rate limit or quota exhaustion"
88
+
89
+ parameter_mappings:
90
+ temperature: "temperature"
91
+ max_tokens: "max_tokens"
92
+ stream: "stream"
93
+ top_p: "top_p"
94
+ stop_sequences: "stop"
95
+ frequency_penalty: "frequency_penalty"
96
+ presence_penalty: "presence_penalty"
97
+ logprobs: "logprobs"
98
+ top_logprobs: "top_logprobs"
99
+ seed: "seed"
100
+ tools: "tools"
101
+ tool_choice: "tool_choice"
102
+ reasoning_effort: "reasoning_effort"
103
+
104
+ response_format: "openai_style"
105
+ response_paths:
106
+ content: "choices[0].message.content"
107
+ tool_calls: "choices[0].message.tool_calls"
108
+ usage: "usage"
109
+ finish_reason: "choices[0].finish_reason"
110
+
111
+ streaming:
112
+ event_format: "data_lines"
113
+ decoder:
114
+ format: "sse"
115
+ delimiter: "\n\n"
116
+ prefix: "data: "
117
+ done_signal: "[DONE]"
118
+ # Allow both normal frames and error frames
119
+ frame_selector: "exists($.choices) || exists($.error) || $.type == 'error'"
120
+ candidate:
121
+ candidate_id_path: "$.choices[*].index"
122
+ fan_out: true
123
+ event_map:
124
+ # Stream error event
125
+ - match: "exists($.error) || $.type == 'error'"
126
+ emit: "StreamError"
127
+ fields:
128
+ type: "$.type"
129
+ event_id: "$.event_id"
130
+ error: "$.error"
131
+ # Text content delta
132
+ - match: "exists($.choices[*].delta.content)"
133
+ emit: "PartialContentDelta"
134
+ fields:
135
+ content: "$.choices[*].delta.content"
136
+ # Tool call start
137
+ - match: "exists($.choices[*].delta.tool_calls[*].function.name)"
138
+ emit: "ToolCallStarted"
139
+ fields:
140
+ tool_call_id: "$.choices[*].delta.tool_calls[*].id"
141
+ tool_name: "$.choices[*].delta.tool_calls[*].function.name"
142
+ index: "$.choices[*].delta.tool_calls[*].index"
143
+ # Tool call arguments streaming
144
+ - match: "exists($.choices[*].delta.tool_calls[*].function.arguments)"
145
+ emit: "PartialToolCall"
146
+ fields:
147
+ arguments: "$.choices[*].delta.tool_calls[*].function.arguments"
148
+ index: "$.choices[*].delta.tool_calls[*].index"
149
+ # Usage metadata
150
+ - match: "exists($.usage)"
151
+ emit: "Metadata"
152
+ fields:
153
+ usage: "$.usage"
154
+ prompt_tokens: "$.usage.prompt_tokens"
155
+ completion_tokens: "$.usage.completion_tokens"
156
+ # Finish with reason
157
+ - match: "exists($.choices[*].finish_reason)"
158
+ emit: "FinalCandidate"
159
+ fields:
160
+ finish_reason: "$.choices[*].finish_reason"
161
+ candidate_index: "$.choices[*].index"
162
+ stop_condition: "$.choices[0].finish_reason != null"
163
+ extra_metadata_path: "$.usage"
164
+ content_path: "choices[0].delta.content"
165
+ tool_call_path: "choices[0].delta.tool_calls"
166
+
167
+ features:
168
+ multi_candidate:
169
+ support_type: "native"
170
+ param_name: "n"
171
+ response_mapping:
172
+ tool_calls:
173
+ path: "choices[0].message.tool_calls"
174
+ fields:
175
+ id: "id"
176
+ name: "function.name"
177
+ args: "function.arguments"
178
+ error:
179
+ message_path: "error.message"
180
+ code_path: "error.code"
181
+ type_path: "error.type"
182
+ param_path: "error.param"
183
+
184
+ capabilities:
185
+ streaming: true
186
+ tools: true
187
+ vision: true
188
+ agentic: true
189
+ parallel_tools: true
190
+ reasoning: true
191
+
192
+ experimental_features:
193
+ - "gork_realtime"
194
+ - "strict_tools"
195
+ - "parallel_tool_calls"
196
+
197
+ # Availability and health checking (v1.1+ extension)
198
+ availability:
199
+ required: false
200
+ regions:
201
+ - global
202
+ check:
203
+ method: GET
204
+ path: "/models"
205
+ expected_status: [200, 401]
206
+ timeout_ms: 3000
@@ -0,0 +1,168 @@
1
+ $schema: "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v1.json"
2
+
3
+ id: yi
4
+ protocol_version: "1.5"
5
+
6
+ name: 零一万物 (Yi/01.AI)
7
+ version: "v1"
8
+ status: stable
9
+ category: ai_provider
10
+ official_url: "https://platform.lingyiwanwu.com/docs"
11
+ support_contact: "https://www.01.ai/contact"
12
+
13
+ endpoint:
14
+ base_url: "https://api.lingyiwanwu.com/v1"
15
+ protocol: https
16
+ timeout_ms: 60000
17
+
18
+ auth:
19
+ type: bearer
20
+ token_env: "YI_API_KEY"
21
+
22
+ payload_format: "openai_style"
23
+
24
+ # OpenAI-compatible API
25
+ api_families: ["chat_completions"]
26
+ default_api_family: "chat_completions"
27
+
28
+ endpoints:
29
+ chat:
30
+ path: "/chat/completions"
31
+ method: "POST"
32
+ adapter: "openai"
33
+
34
+ services:
35
+ list_models:
36
+ path: "/models"
37
+ method: "GET"
38
+ response_binding: "data"
39
+
40
+ termination:
41
+ source_field: "finish_reason"
42
+ mapping:
43
+ stop: "end_turn"
44
+ length: "max_tokens"
45
+ tool_calls: "tool_use"
46
+ notes:
47
+ - "OpenAI-compatible finish_reason."
48
+ - "Yi is founded by Kai-Fu Lee, known for open-source Yi series models."
49
+
50
+ tooling:
51
+ source_model: "openai_tool_calls"
52
+ tool_use:
53
+ id_path: "id"
54
+ name_path: "function.name"
55
+ input_path: "function.arguments"
56
+ input_format: "json_string"
57
+ notes:
58
+ - "Supports OpenAI-compatible function calling."
59
+
60
+ retry_policy:
61
+ strategy: "exponential_backoff"
62
+ max_retries: 3
63
+ min_delay_ms: 1000
64
+ max_delay_ms: 30000
65
+ jitter: "full"
66
+ retry_on_http_status: [429, 500, 502, 503]
67
+
68
+ error_classification:
69
+ by_http_status:
70
+ "400": "invalid_request"
71
+ "401": "authentication"
72
+ "403": "permission_denied"
73
+ "404": "not_found"
74
+ "429": "rate_limited"
75
+ "500": "server_error"
76
+ "503": "overloaded"
77
+
78
+ parameter_mappings:
79
+ temperature: "temperature"
80
+ max_tokens: "max_tokens"
81
+ stream: "stream"
82
+ top_p: "top_p"
83
+ stop_sequences: "stop"
84
+ tools: "tools"
85
+ tool_choice: "tool_choice"
86
+
87
+ response_format: "openai_style"
88
+
89
+ response_paths:
90
+ content: "choices[0].message.content"
91
+ tool_calls: "choices[0].message.tool_calls"
92
+ usage: "usage"
93
+ finish_reason: "choices[0].finish_reason"
94
+
95
+ streaming:
96
+ event_format: "data_lines"
97
+ decoder:
98
+ format: "sse"
99
+ delimiter: "\n\n"
100
+ prefix: "data: "
101
+ done_signal: "[DONE]"
102
+ content_path: "choices[0].delta.content"
103
+ tool_call_path: "choices[0].delta.tool_calls"
104
+ usage_path: "usage"
105
+ frame_selector: "exists($.choices) || exists($.error)"
106
+ event_map:
107
+ - match: "exists($.choices[*].delta.content)"
108
+ emit: "PartialContentDelta"
109
+ fields:
110
+ content: "$.choices[*].delta.content"
111
+ - match: "exists($.choices[*].delta.tool_calls[*].function.name)"
112
+ emit: "ToolCallStarted"
113
+ fields:
114
+ tool_call_id: "$.choices[*].delta.tool_calls[*].id"
115
+ tool_name: "$.choices[*].delta.tool_calls[*].function.name"
116
+ index: "$.choices[*].delta.tool_calls[*].index"
117
+ - match: "exists($.choices[*].delta.tool_calls[*].function.arguments)"
118
+ emit: "PartialToolCall"
119
+ fields:
120
+ arguments: "$.choices[*].delta.tool_calls[*].function.arguments"
121
+ index: "$.choices[*].delta.tool_calls[*].index"
122
+ - match: "exists($.usage)"
123
+ emit: "Metadata"
124
+ fields:
125
+ usage: "$.usage"
126
+ - match: "exists($.choices[*].finish_reason)"
127
+ emit: "FinalCandidate"
128
+ fields:
129
+ finish_reason: "$.choices[*].finish_reason"
130
+ stop_condition: "$.choices[0].finish_reason != null"
131
+
132
+ features:
133
+ multi_candidate:
134
+ support_type: "native"
135
+ param_name: "n"
136
+ response_mapping:
137
+ tool_calls:
138
+ path: "choices[0].message.tool_calls"
139
+ fields:
140
+ id: "id"
141
+ name: "function.name"
142
+ args: "function.arguments"
143
+ error:
144
+ message_path: "error.message"
145
+ code_path: "error.code"
146
+
147
+ capabilities:
148
+ streaming: true
149
+ tools: true
150
+ vision: true
151
+ agentic: true
152
+ parallel_tools: false
153
+ reasoning: false
154
+
155
+ availability:
156
+ required: false
157
+ regions:
158
+ - cn
159
+ - global
160
+ check:
161
+ method: GET
162
+ path: "/models"
163
+ expected_status: [200, 401]
164
+ timeout_ms: 5000
165
+
166
+ experimental_features:
167
+ - "open_source_models"
168
+ - "bilingual"