mirror of
https://github.com/Alishahryar1/free-claude-code.git
synced 2026-04-28 03:20:01 +00:00
When NVIDIA_NIM_API_KEY or OPENROUTER_API_KEY is empty or not set, the proxy forwarded requests without a valid Authorization header, causing providers to return 403 with 'Header of type authorization was missing'. Now fail fast with HTTP 503 and a clear message telling users to add the key to .env, with links to obtain keys. Fixes #29 Co-authored-by: Ali Khokhar <alishahryar2@gmail.com>
111 lines
4.3 KiB
Python
111 lines
4.3 KiB
Python
"""Dependency injection for FastAPI."""
|
|
|
|
from typing import Optional
|
|
|
|
from fastapi import HTTPException
|
|
from loguru import logger
|
|
|
|
from config.settings import Settings, get_settings as _get_settings, NVIDIA_NIM_BASE_URL
|
|
from providers.base import BaseProvider, ProviderConfig
|
|
|
|
|
|
# Global provider instance (singleton)
|
|
_provider: Optional[BaseProvider] = None
|
|
|
|
|
|
def get_settings() -> Settings:
|
|
"""Get application settings via dependency injection."""
|
|
return _get_settings()
|
|
|
|
|
|
def get_provider() -> BaseProvider:
|
|
"""Get or create the provider instance based on settings.provider_type."""
|
|
global _provider
|
|
if _provider is None:
|
|
settings = get_settings()
|
|
|
|
if settings.provider_type == "nvidia_nim":
|
|
if (
|
|
not settings.nvidia_nim_api_key
|
|
or not settings.nvidia_nim_api_key.strip()
|
|
):
|
|
raise HTTPException(
|
|
status_code=503,
|
|
detail=(
|
|
"NVIDIA_NIM_API_KEY is not set. Add it to your .env file. "
|
|
"Get a key at https://build.nvidia.com/settings/api-keys"
|
|
),
|
|
)
|
|
from providers.nvidia_nim import NvidiaNimProvider
|
|
|
|
config = ProviderConfig(
|
|
api_key=settings.nvidia_nim_api_key,
|
|
base_url=NVIDIA_NIM_BASE_URL,
|
|
rate_limit=settings.provider_rate_limit,
|
|
rate_window=settings.provider_rate_window,
|
|
http_read_timeout=settings.http_read_timeout,
|
|
http_write_timeout=settings.http_write_timeout,
|
|
http_connect_timeout=settings.http_connect_timeout,
|
|
)
|
|
_provider = NvidiaNimProvider(config, nim_settings=settings.nim)
|
|
logger.info("Provider initialized: %s", settings.provider_type)
|
|
elif settings.provider_type == "open_router":
|
|
if (
|
|
not settings.open_router_api_key
|
|
or not settings.open_router_api_key.strip()
|
|
):
|
|
raise HTTPException(
|
|
status_code=503,
|
|
detail=(
|
|
"OPENROUTER_API_KEY is not set. Add it to your .env file. "
|
|
"Get a key at https://openrouter.ai/keys"
|
|
),
|
|
)
|
|
from providers.open_router import OpenRouterProvider
|
|
|
|
config = ProviderConfig(
|
|
api_key=settings.open_router_api_key,
|
|
base_url="https://openrouter.ai/api/v1",
|
|
rate_limit=settings.provider_rate_limit,
|
|
rate_window=settings.provider_rate_window,
|
|
http_read_timeout=settings.http_read_timeout,
|
|
http_write_timeout=settings.http_write_timeout,
|
|
http_connect_timeout=settings.http_connect_timeout,
|
|
)
|
|
_provider = OpenRouterProvider(config)
|
|
logger.info("Provider initialized: %s", settings.provider_type)
|
|
elif settings.provider_type == "lmstudio":
|
|
from providers.lmstudio import LMStudioProvider
|
|
|
|
config = ProviderConfig(
|
|
api_key="lm-studio",
|
|
base_url=settings.lm_studio_base_url,
|
|
rate_limit=settings.provider_rate_limit,
|
|
rate_window=settings.provider_rate_window,
|
|
http_read_timeout=settings.http_read_timeout,
|
|
http_write_timeout=settings.http_write_timeout,
|
|
http_connect_timeout=settings.http_connect_timeout,
|
|
)
|
|
_provider = LMStudioProvider(config)
|
|
logger.info("Provider initialized: %s", settings.provider_type)
|
|
else:
|
|
logger.error(
|
|
"Unknown provider_type: '%s'. Supported: 'nvidia_nim', 'open_router', 'lmstudio'",
|
|
settings.provider_type,
|
|
)
|
|
raise ValueError(
|
|
f"Unknown provider_type: '{settings.provider_type}'. "
|
|
f"Supported: 'nvidia_nim', 'open_router', 'lmstudio'"
|
|
)
|
|
return _provider
|
|
|
|
|
|
async def cleanup_provider():
|
|
"""Cleanup provider resources."""
|
|
global _provider
|
|
if _provider:
|
|
client = getattr(_provider, "_client", None)
|
|
if client and hasattr(client, "aclose"):
|
|
await client.aclose()
|
|
_provider = None
|
|
logger.debug("Provider cleanup completed")
|