@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,274 @@
1
+ {
2
+ "$schema": "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v2/provider.json",
3
+ "id": "qwen",
4
+ "protocol_version": "2.0",
5
+ "name": "Qwen (DashScope)",
6
+ "version": "3.0.0",
7
+ "status": "stable",
8
+ "category": "ai_provider",
9
+ "official_url": "https://help.aliyun.com/zh/model-studio",
10
+ "support_contact": "https://help.aliyun.com",
11
+ "endpoint": {
12
+ "base_url": "https://dashscope.aliyuncs.com/compatible-mode/v1",
13
+ "chat": "/chat/completions",
14
+ "auth": {
15
+ "type": "bearer",
16
+ "header": "Authorization",
17
+ "prefix": "Bearer",
18
+ "token_env": "QWEN_API_KEY"
19
+ }
20
+ },
21
+ "error_classification": {
22
+ "by_http_status": {
23
+ "400": "invalid_request",
24
+ "401": "authentication",
25
+ "403": "permission_denied",
26
+ "404": "not_found",
27
+ "429": "rate_limited",
28
+ "500": "server_error",
29
+ "503": "overloaded"
30
+ }
31
+ },
32
+ "capabilities": {
33
+ "required": [
34
+ "text",
35
+ "streaming",
36
+ "tools"
37
+ ],
38
+ "optional": [
39
+ "vision",
40
+ "audio",
41
+ "video",
42
+ "parallel_tools",
43
+ "reasoning",
44
+ "structured_output",
45
+ "image_generation",
46
+ "stt",
47
+ "tts"
48
+ ],
49
+ "feature_flags": {
50
+ "structured_output": true,
51
+ "parallel_tool_calls": true,
52
+ "streaming_usage": true,
53
+ "system_messages": true,
54
+ "image_generation": true
55
+ }
56
+ },
57
+ "capability_profile": {
58
+ "phase": "ios_v1",
59
+ "inputs": {
60
+ "modalities": [
61
+ "text",
62
+ "image",
63
+ "audio"
64
+ ]
65
+ },
66
+ "outcomes": {
67
+ "types": [
68
+ "text_completion",
69
+ "structured_json",
70
+ "tool_call_sequence"
71
+ ]
72
+ },
73
+ "systems": {
74
+ "requires": [
75
+ "mcp",
76
+ "search"
77
+ ]
78
+ }
79
+ },
80
+ "parameters": {
81
+ "temperature": {
82
+ "type": "float",
83
+ "range": [
84
+ 0,
85
+ 2
86
+ ],
87
+ "default": 1
88
+ },
89
+ "max_tokens": {
90
+ "type": "integer",
91
+ "min": 1,
92
+ "max": 32000
93
+ },
94
+ "top_p": {
95
+ "type": "float",
96
+ "range": [
97
+ 0,
98
+ 1
99
+ ]
100
+ },
101
+ "stream": {
102
+ "type": "boolean"
103
+ }
104
+ },
105
+ "parameter_mappings": {
106
+ "temperature": "temperature",
107
+ "max_tokens": "max_tokens",
108
+ "stream": "stream",
109
+ "top_p": "top_p",
110
+ "tools": "tools",
111
+ "tool_choice": "tool_choice"
112
+ },
113
+ "streaming": {
114
+ "decoder": {
115
+ "format": "sse",
116
+ "strategy": "openai_chat",
117
+ "done_signal": "[DONE]",
118
+ "prefix": "data: "
119
+ },
120
+ "content_path": "$.choices[0].delta.content",
121
+ "tool_call_path": "$.choices[0].delta.tool_calls",
122
+ "usage_path": "$.usage",
123
+ "event_map": [
124
+ {
125
+ "match": "exists($.choices[*].delta.content)",
126
+ "emit": "PartialContentDelta",
127
+ "fields": {
128
+ "content": "$.choices[*].delta.content"
129
+ }
130
+ },
131
+ {
132
+ "match": "exists($.choices[*].delta.tool_calls)",
133
+ "emit": "PartialToolCall",
134
+ "fields": {
135
+ "tool_calls": "$.choices[*].delta.tool_calls"
136
+ }
137
+ },
138
+ {
139
+ "match": "exists($.usage)",
140
+ "emit": "Metadata",
141
+ "fields": {
142
+ "usage": "$.usage"
143
+ }
144
+ },
145
+ {
146
+ "match": "$.choices[*].finish_reason != null",
147
+ "emit": "StreamEnd",
148
+ "fields": {
149
+ "finish_reason": "$.choices[*].finish_reason"
150
+ }
151
+ }
152
+ ],
153
+ "stop_condition": "$.choices[0].finish_reason != null"
154
+ },
155
+ "multimodal": {
156
+ "input": {
157
+ "vision": {
158
+ "supported": true,
159
+ "formats": [
160
+ "jpeg",
161
+ "png",
162
+ "gif",
163
+ "webp"
164
+ ],
165
+ "encoding_methods": [
166
+ "base64_inline",
167
+ "url"
168
+ ],
169
+ "document_understanding": true
170
+ },
171
+ "audio": {
172
+ "supported": true,
173
+ "formats": [
174
+ "mp3",
175
+ "wav",
176
+ "flac",
177
+ "ogg",
178
+ "aac"
179
+ ],
180
+ "speech_recognition": true,
181
+ "real_time_streaming": true
182
+ },
183
+ "video": {
184
+ "supported": true,
185
+ "formats": [
186
+ "mp4",
187
+ "mov",
188
+ "avi",
189
+ "webm"
190
+ ],
191
+ "frame_extraction": "automatic",
192
+ "audio_track": true,
193
+ "temporal_reasoning": true
194
+ }
195
+ },
196
+ "output": {
197
+ "text": true,
198
+ "audio": {
199
+ "supported": true,
200
+ "formats": [
201
+ "wav",
202
+ "mp3",
203
+ "opus"
204
+ ],
205
+ "real_time_tts": true,
206
+ "natural_voice": true,
207
+ "voice_selection": true
208
+ },
209
+ "image": {
210
+ "supported": true,
211
+ "formats": [
212
+ "png",
213
+ "jpeg",
214
+ "webp"
215
+ ]
216
+ },
217
+ "video": {
218
+ "supported": false
219
+ }
220
+ }
221
+ },
222
+ "api_families": [
223
+ "chat_completions",
224
+ "completions"
225
+ ],
226
+ "default_api_family": "chat_completions",
227
+ "endpoints": {
228
+ "chat": {
229
+ "path": "/chat/completions",
230
+ "method": "POST",
231
+ "adapter": "openai"
232
+ }
233
+ },
234
+ "services": {
235
+ "list_models": {
236
+ "path": "/models",
237
+ "method": "GET",
238
+ "response_binding": "data"
239
+ }
240
+ },
241
+ "retry_policy": {
242
+ "strategy": "exponential_backoff",
243
+ "max_retries": 2,
244
+ "min_delay_ms": 1000,
245
+ "max_delay_ms": 8000,
246
+ "jitter": "full",
247
+ "retry_on_http_status": [
248
+ 408,
249
+ 409,
250
+ 429,
251
+ 500,
252
+ 503
253
+ ]
254
+ },
255
+ "termination": {
256
+ "source_field": "finish_reason",
257
+ "mapping": {
258
+ "stop": "end_turn",
259
+ "length": "max_tokens",
260
+ "tool_calls": "tool_use",
261
+ "content_filter": "refusal"
262
+ }
263
+ },
264
+ "metadata": {
265
+ "api_compatibility": "openai",
266
+ "regional": {
267
+ "primary": "china"
268
+ },
269
+ "sdk": {
270
+ "python": "openai",
271
+ "typescript": "openai"
272
+ }
273
+ }
274
+ }
@@ -0,0 +1,257 @@
1
+ {
2
+ "$schema": "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v2/provider.json",
3
+ "id": "zhipu",
4
+ "protocol_version": "2.0",
5
+ "name": "Zhipu AI",
6
+ "version": "5.0.0",
7
+ "status": "stable",
8
+ "category": "ai_provider",
9
+ "official_url": "https://open.bigmodel.cn/dev/api",
10
+ "support_contact": "https://open.bigmodel.cn/",
11
+ "endpoint": {
12
+ "base_url": "https://open.bigmodel.cn/api/paas/v4",
13
+ "chat": "/chat/completions",
14
+ "auth": {
15
+ "type": "bearer",
16
+ "header": "Authorization",
17
+ "prefix": "Bearer",
18
+ "token_env": "ZHIPU_API_KEY"
19
+ }
20
+ },
21
+ "error_classification": {
22
+ "by_http_status": {
23
+ "400": "invalid_request",
24
+ "401": "authentication",
25
+ "403": "permission_denied",
26
+ "404": "not_found",
27
+ "429": "rate_limited",
28
+ "500": "server_error",
29
+ "503": "overloaded"
30
+ },
31
+ "by_error_code": {
32
+ "context_length_exceeded": "request_too_large",
33
+ "model_not_found": "not_found",
34
+ "rate_limit_exceeded": "rate_limited",
35
+ "insufficient_quota": "quota_exhausted"
36
+ }
37
+ },
38
+ "capabilities": {
39
+ "required": [
40
+ "text",
41
+ "streaming",
42
+ "tools"
43
+ ],
44
+ "optional": [
45
+ "parallel_tools",
46
+ "agentic",
47
+ "reasoning",
48
+ "structured_output"
49
+ ],
50
+ "feature_flags": {
51
+ "structured_output": true,
52
+ "parallel_tool_calls": true,
53
+ "streaming_usage": true,
54
+ "system_messages": true
55
+ }
56
+ },
57
+ "capability_profile": {
58
+ "phase": "ios_v1",
59
+ "inputs": {
60
+ "modalities": [
61
+ "text",
62
+ "image"
63
+ ]
64
+ },
65
+ "outcomes": {
66
+ "types": [
67
+ "text_completion",
68
+ "structured_json",
69
+ "tool_call_sequence"
70
+ ]
71
+ },
72
+ "systems": {
73
+ "requires": [
74
+ "mcp",
75
+ "search"
76
+ ]
77
+ }
78
+ },
79
+ "parameters": {
80
+ "temperature": {
81
+ "type": "float",
82
+ "range": [
83
+ 0,
84
+ 2
85
+ ],
86
+ "default": 1
87
+ },
88
+ "max_tokens": {
89
+ "type": "integer",
90
+ "min": 1,
91
+ "max": 128000
92
+ },
93
+ "top_p": {
94
+ "type": "float",
95
+ "range": [
96
+ 0,
97
+ 1
98
+ ]
99
+ },
100
+ "stream": {
101
+ "type": "boolean"
102
+ }
103
+ },
104
+ "parameter_mappings": {
105
+ "temperature": "temperature",
106
+ "max_tokens": "max_tokens",
107
+ "stream": "stream",
108
+ "top_p": "top_p",
109
+ "tools": "tools",
110
+ "tool_choice": "tool_choice"
111
+ },
112
+ "streaming": {
113
+ "decoder": {
114
+ "format": "sse",
115
+ "strategy": "openai_chat",
116
+ "done_signal": "[DONE]",
117
+ "prefix": "data: "
118
+ },
119
+ "content_path": "$.choices[0].delta.content",
120
+ "tool_call_path": "$.choices[0].delta.tool_calls",
121
+ "usage_path": "$.usage",
122
+ "event_map": [
123
+ {
124
+ "match": "exists($.choices[*].delta.content)",
125
+ "emit": "PartialContentDelta",
126
+ "fields": {
127
+ "content": "$.choices[*].delta.content"
128
+ }
129
+ },
130
+ {
131
+ "match": "exists($.choices[*].delta.tool_calls)",
132
+ "emit": "PartialToolCall",
133
+ "fields": {
134
+ "tool_calls": "$.choices[*].delta.tool_calls"
135
+ }
136
+ },
137
+ {
138
+ "match": "exists($.usage)",
139
+ "emit": "Metadata",
140
+ "fields": {
141
+ "usage": "$.usage"
142
+ }
143
+ },
144
+ {
145
+ "match": "$.choices[*].finish_reason != null",
146
+ "emit": "StreamEnd",
147
+ "fields": {
148
+ "finish_reason": "$.choices[*].finish_reason"
149
+ }
150
+ }
151
+ ],
152
+ "stop_condition": "$.choices[0].finish_reason != null"
153
+ },
154
+ "multimodal": {
155
+ "input": {
156
+ "vision": {
157
+ "supported": false
158
+ },
159
+ "audio": {
160
+ "supported": false
161
+ },
162
+ "video": {
163
+ "supported": false
164
+ }
165
+ },
166
+ "output": {
167
+ "text": true,
168
+ "audio": {
169
+ "supported": false
170
+ },
171
+ "image": {
172
+ "supported": false
173
+ }
174
+ }
175
+ },
176
+ "api_families": [
177
+ "chat_completions"
178
+ ],
179
+ "default_api_family": "chat_completions",
180
+ "endpoints": {
181
+ "chat": {
182
+ "path": "/chat/completions",
183
+ "method": "POST",
184
+ "adapter": "openai"
185
+ }
186
+ },
187
+ "services": {
188
+ "list_models": {
189
+ "path": "/models",
190
+ "method": "GET"
191
+ }
192
+ },
193
+ "retry_policy": {
194
+ "strategy": "exponential_backoff",
195
+ "max_retries": 3,
196
+ "min_delay_ms": 1000,
197
+ "max_delay_ms": 30000,
198
+ "jitter": "full",
199
+ "retry_on_http_status": [
200
+ 429,
201
+ 500,
202
+ 502,
203
+ 503
204
+ ]
205
+ },
206
+ "termination": {
207
+ "source_field": "finish_reason",
208
+ "mapping": {
209
+ "stop": "end_turn",
210
+ "length": "max_tokens",
211
+ "tool_calls": "tool_use"
212
+ }
213
+ },
214
+ "metadata": {
215
+ "api_compatibility": "openai",
216
+ "open_source": {
217
+ "license": "MIT",
218
+ "hugging_face": "https://huggingface.co/zhipuai/glm-5"
219
+ },
220
+ "agentic_engineering": {
221
+ "supported": true,
222
+ "capabilities": [
223
+ "long_horizon_planning",
224
+ "multi_step_workflows",
225
+ "autonomous_debugging"
226
+ ]
227
+ },
228
+ "models": {
229
+ "glm-5": {
230
+ "context_window": 200000,
231
+ "max_output_tokens": 128000,
232
+ "release_date": "2026-02-11",
233
+ "architecture": {
234
+ "type": "moe",
235
+ "total": "744B",
236
+ "active": "40B"
237
+ },
238
+ "pricing": {
239
+ "input_per_1m": 1,
240
+ "output_per_1m": 3.2
241
+ }
242
+ }
243
+ },
244
+ "regional": {
245
+ "primary": "china",
246
+ "alternative_base": "https://api.z.ai/v1",
247
+ "international_partners": [
248
+ "aimlapi"
249
+ ]
250
+ },
251
+ "sdk": {
252
+ "note": "OpenAI-compatible — use openai SDK with base_url override",
253
+ "python": "openai",
254
+ "typescript": "openai"
255
+ }
256
+ }
257
+ }
@@ -0,0 +1,182 @@
1
+ {
2
+ "$schema": "https://raw.githubusercontent.com/ailib-official/ai-protocol/main/schemas/v2/provider.json",
3
+ "id": "anthropic",
4
+ "protocol_version": "2.0",
5
+ "name": "Anthropic",
6
+ "version": "v1",
7
+ "status": "stable",
8
+ "category": "ai_provider",
9
+ "official_url": "https://docs.anthropic.com",
10
+ "support_contact": "https://support.anthropic.com",
11
+ "endpoint": {
12
+ "base_url": "https://api.anthropic.com/v1",
13
+ "chat": "/messages",
14
+ "auth": {
15
+ "type": "custom_header",
16
+ "header": "x-api-key",
17
+ "token_env": "ANTHROPIC_API_KEY",
18
+ "extra_headers": [
19
+ {
20
+ "name": "anthropic-version",
21
+ "value": "2023-06-01"
22
+ }
23
+ ]
24
+ }
25
+ },
26
+ "error_classification": {
27
+ "by_http_status": {
28
+ "400": "invalid_request",
29
+ "401": "authentication",
30
+ "403": "permission_denied",
31
+ "404": "not_found",
32
+ "413": "request_too_large",
33
+ "429": "rate_limited",
34
+ "500": "server_error",
35
+ "529": "overloaded"
36
+ },
37
+ "by_error_code": {
38
+ "invalid_request_error": "invalid_request",
39
+ "authentication_error": "authentication",
40
+ "permission_error": "permission_denied",
41
+ "not_found_error": "not_found",
42
+ "request_too_large": "request_too_large",
43
+ "rate_limit_error": "rate_limited",
44
+ "api_error": "server_error",
45
+ "overloaded_error": "overloaded"
46
+ }
47
+ },
48
+ "capabilities": {
49
+ "required": [
50
+ "text",
51
+ "streaming"
52
+ ],
53
+ "optional": [
54
+ "vision",
55
+ "tools",
56
+ "parallel_tools",
57
+ "agentic",
58
+ "reasoning",
59
+ "batch"
60
+ ],
61
+ "feature_flags": {
62
+ "structured_output": false,
63
+ "parallel_tool_calls": true,
64
+ "extended_thinking": true,
65
+ "streaming_usage": true,
66
+ "system_messages": true
67
+ }
68
+ },
69
+ "parameters": {
70
+ "temperature": {
71
+ "type": "float",
72
+ "range": [
73
+ 0,
74
+ 2
75
+ ],
76
+ "default": 1
77
+ },
78
+ "max_tokens": {
79
+ "type": "integer",
80
+ "min": 1,
81
+ "max": 8192,
82
+ "required": true
83
+ },
84
+ "top_p": {
85
+ "type": "float",
86
+ "range": [
87
+ 0,
88
+ 1
89
+ ]
90
+ },
91
+ "top_k": {
92
+ "type": "integer",
93
+ "min": 0
94
+ },
95
+ "stream": {
96
+ "type": "boolean"
97
+ }
98
+ },
99
+ "streaming": {
100
+ "decoder": {
101
+ "format": "anthropic_sse",
102
+ "strategy": "anthropic_event_stream"
103
+ },
104
+ "event_map": [
105
+ {
106
+ "match": "$.type == 'content_block_delta' && $.delta.type == 'text_delta'",
107
+ "emit": "PartialContentDelta",
108
+ "extract": {
109
+ "content": "$.delta.text"
110
+ }
111
+ },
112
+ {
113
+ "match": "$.type == 'content_block_delta' && $.delta.type == 'input_json_delta'",
114
+ "emit": "PartialToolCall",
115
+ "extract": {
116
+ "partial_json": "$.delta.partial_json"
117
+ }
118
+ },
119
+ {
120
+ "match": "$.type == 'content_block_delta' && $.delta.type == 'thinking_delta'",
121
+ "emit": "ThinkingDelta",
122
+ "extract": {
123
+ "thinking": "$.delta.thinking"
124
+ }
125
+ },
126
+ {
127
+ "match": "$.type == 'message_delta'",
128
+ "emit": "StreamEnd",
129
+ "extract": {
130
+ "finish_reason": "$.delta.stop_reason",
131
+ "usage": "$.usage"
132
+ }
133
+ }
134
+ ],
135
+ "accumulator": {
136
+ "stateful_tool_parsing": true,
137
+ "key_path": "$.delta.partial_json",
138
+ "flush_on": "$.type == 'content_block_stop'"
139
+ }
140
+ },
141
+ "api_families": [
142
+ "messages"
143
+ ],
144
+ "default_api_family": "messages",
145
+ "endpoints": {
146
+ "chat": {
147
+ "path": "/messages",
148
+ "method": "POST",
149
+ "adapter": "anthropic"
150
+ }
151
+ },
152
+ "rate_limit_headers": {
153
+ "retry_after": "retry-after",
154
+ "requests_limit": "anthropic-ratelimit-requests-limit",
155
+ "requests_remaining": "anthropic-ratelimit-requests-remaining",
156
+ "tokens_limit": "anthropic-ratelimit-tokens-limit",
157
+ "tokens_remaining": "anthropic-ratelimit-tokens-remaining"
158
+ },
159
+ "retry_policy": {
160
+ "strategy": "exponential_backoff",
161
+ "max_retries": 2,
162
+ "min_delay_ms": 1000,
163
+ "max_delay_ms": 60000,
164
+ "jitter": "full",
165
+ "retry_on_http_status": [
166
+ 408,
167
+ 409,
168
+ 429,
169
+ 500,
170
+ 529
171
+ ]
172
+ },
173
+ "termination": {
174
+ "source_field": "stop_reason",
175
+ "mapping": {
176
+ "end_turn": "end_turn",
177
+ "max_tokens": "max_tokens",
178
+ "stop_sequence": "stop_sequence",
179
+ "tool_use": "tool_use"
180
+ }
181
+ }
182
+ }