From f23548f296aa91b470d39d09a462676f964e3ad3 Mon Sep 17 00:00:00 2001 From: Kyya Wang Date: Tue, 3 Feb 2026 03:09:13 +0000 Subject: [PATCH 1/2] feat: add DeepSeek provider support --- .gitignore | 4 +++- nanobot/config/schema.py | 4 +++- nanobot/providers/litellm_provider.py | 6 ++++++ 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index 9720f3b..e543534 100644 --- a/.gitignore +++ b/.gitignore @@ -12,4 +12,6 @@ docs/ *.pyw *.pyz *.pywz -*.pyzz \ No newline at end of file +*.pyzz +.venv/ +__pycache__/ diff --git a/nanobot/config/schema.py b/nanobot/config/schema.py index c2109a1..ad2e270 100644 --- a/nanobot/config/schema.py +++ b/nanobot/config/schema.py @@ -50,6 +50,7 @@ class ProvidersConfig(BaseModel): anthropic: ProviderConfig = Field(default_factory=ProviderConfig) openai: ProviderConfig = Field(default_factory=ProviderConfig) openrouter: ProviderConfig = Field(default_factory=ProviderConfig) + deepseek: ProviderConfig = Field(default_factory=ProviderConfig) zhipu: ProviderConfig = Field(default_factory=ProviderConfig) vllm: ProviderConfig = Field(default_factory=ProviderConfig) gemini: ProviderConfig = Field(default_factory=ProviderConfig) @@ -91,9 +92,10 @@ class Config(BaseSettings): return Path(self.agents.defaults.workspace).expanduser() def get_api_key(self) -> str | None: - """Get API key in priority order: OpenRouter > Anthropic > OpenAI > Gemini > Zhipu > vLLM.""" + """Get API key in priority order: OpenRouter > DeepSeek > Anthropic > OpenAI > Gemini > Zhipu > vLLM.""" return ( self.providers.openrouter.api_key or + self.providers.deepseek.api_key or self.providers.anthropic.api_key or self.providers.openai.api_key or self.providers.gemini.api_key or diff --git a/nanobot/providers/litellm_provider.py b/nanobot/providers/litellm_provider.py index 42b4bf5..f6dc914 100644 --- a/nanobot/providers/litellm_provider.py +++ b/nanobot/providers/litellm_provider.py @@ -43,6 +43,8 @@ class LiteLLMProvider(LLMProvider): elif self.is_vllm: # vLLM/custom endpoint - uses OpenAI-compatible API os.environ["OPENAI_API_KEY"] = api_key + elif "deepseek" in default_model: + os.environ.setdefault("DEEPSEEK_API_KEY", api_key) elif "anthropic" in default_model: os.environ.setdefault("ANTHROPIC_API_KEY", api_key) elif "openai" in default_model or "gpt" in default_model: @@ -103,6 +105,10 @@ class LiteLLMProvider(LLMProvider): if "gemini" in model.lower() and not model.startswith("gemini/"): model = f"gemini/{model}" + # Force set env vars for the provider based on model + if "deepseek" in model: + os.environ["DEEPSEEK_API_KEY"] = self.api_key + kwargs: dict[str, Any] = { "model": model, "messages": messages, From 301fba568b7d074e17673ae3f029fecd55621c48 Mon Sep 17 00:00:00 2001 From: Re-bin Date: Thu, 5 Feb 2026 08:55:41 +0000 Subject: [PATCH 2/2] refactor: remove redundant env var setting, add DeepSeek to docs --- README.md | 1 + nanobot/providers/litellm_provider.py | 4 ---- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/README.md b/README.md index 47f9315..923ab64 100644 --- a/README.md +++ b/README.md @@ -306,6 +306,7 @@ Config file: `~/.nanobot/config.json` | `openrouter` | LLM (recommended, access to all models) | [openrouter.ai](https://openrouter.ai) | | `anthropic` | LLM (Claude direct) | [console.anthropic.com](https://console.anthropic.com) | | `openai` | LLM (GPT direct) | [platform.openai.com](https://platform.openai.com) | +| `deepseek` | LLM (DeepSeek direct) | [platform.deepseek.com](https://platform.deepseek.com) | | `groq` | LLM + **Voice transcription** (Whisper) | [console.groq.com](https://console.groq.com) | | `gemini` | LLM (Gemini direct) | [aistudio.google.com](https://aistudio.google.com) | diff --git a/nanobot/providers/litellm_provider.py b/nanobot/providers/litellm_provider.py index eeaca94..d010d81 100644 --- a/nanobot/providers/litellm_provider.py +++ b/nanobot/providers/litellm_provider.py @@ -107,10 +107,6 @@ class LiteLLMProvider(LLMProvider): if "gemini" in model.lower() and not model.startswith("gemini/"): model = f"gemini/{model}" - # Force set env vars for the provider based on model - if "deepseek" in model: - os.environ["DEEPSEEK_API_KEY"] = self.api_key - kwargs: dict[str, Any] = { "model": model, "messages": messages,