90 lines
2.3 KiB
Python
90 lines
2.3 KiB
Python
"""Model name validators for each provider.
|
|
|
|
Only validates model names - does NOT enforce limits.
|
|
Let LLM providers use their own defaults for unspecified params.
|
|
"""
|
|
|
|
VALID_MODELS = {
|
|
"openai": [
|
|
# GPT-5 series
|
|
"gpt-5.4-pro",
|
|
"gpt-5.4",
|
|
"gpt-5.2",
|
|
"gpt-5.1",
|
|
"gpt-5",
|
|
"gpt-5-mini",
|
|
"gpt-5-nano",
|
|
# GPT-4.1 series
|
|
"gpt-4.1",
|
|
"gpt-4.1-mini",
|
|
"gpt-4.1-nano",
|
|
],
|
|
"anthropic": [
|
|
# Claude 4.6 series (latest)
|
|
"claude-opus-4-6",
|
|
"claude-sonnet-4-6",
|
|
# Claude 4.5 series
|
|
"claude-opus-4-5",
|
|
"claude-sonnet-4-5",
|
|
"claude-haiku-4-5",
|
|
],
|
|
"google": [
|
|
# Gemini 3.1 series (preview)
|
|
"gemini-3.1-pro-preview",
|
|
"gemini-3.1-flash-lite-preview",
|
|
# Gemini 3 series (preview)
|
|
"gemini-3-flash-preview",
|
|
# Gemini 2.5 series
|
|
"gemini-2.5-pro",
|
|
"gemini-2.5-flash",
|
|
"gemini-2.5-flash-lite",
|
|
],
|
|
"xai": [
|
|
# Grok 4.1 series
|
|
"grok-4-1-fast-reasoning",
|
|
"grok-4-1-fast-non-reasoning",
|
|
# Grok 4 series
|
|
"grok-4-0709",
|
|
"grok-4-fast-reasoning",
|
|
"grok-4-fast-non-reasoning",
|
|
],
|
|
"groq": [
|
|
# Llama series (hosted by Groq)
|
|
"llama-3.3-70b-versatile",
|
|
"llama-3.1-70b-versatile",
|
|
"llama-3.1-8b-instant",
|
|
"llama-3-8b-8192",
|
|
# Mixtral series (hosted by Groq)
|
|
"mixtral-8x7b-32768",
|
|
"mixtral-8x22b-32768",
|
|
# Other models via Groq
|
|
"openai/gpt-oss-120b",
|
|
],
|
|
"kilo": [
|
|
# Kilo Gateway supports models from multiple providers
|
|
# Example models from various providers accessible via Kilo
|
|
"anthropic/claude-sonnet-4.5",
|
|
"anthropic/claude-opus-4.5",
|
|
"openai/gpt-5-mini",
|
|
"google/gemini-2.5-flash",
|
|
# Minimax models via Kilo
|
|
"minimax/minimax-m2.5:free",
|
|
],
|
|
}
|
|
|
|
|
|
def validate_model(provider: str, model: str) -> bool:
|
|
"""Check if model name is valid for the given provider.
|
|
|
|
For ollama, openrouter, kilo - any model is accepted.
|
|
"""
|
|
provider_lower = provider.lower()
|
|
|
|
if provider_lower in ("ollama", "openrouter", "kilo"):
|
|
return True
|
|
|
|
if provider_lower not in VALID_MODELS:
|
|
return True
|
|
|
|
return model in VALID_MODELS[provider_lower]
|