ppt-tool/backend/utils/model_availability.py
Vadym Samoilenko cf21ba4516 Phase 1-2: Foundation + Admin Panel & Client Management
Phase 1 (Foundation):
- Project restructure (presenton-main → backend/ + frontend/)
- Database schema (8 new models, Alembic config, seed script)
- Auth (Azure AD SSO + dev bypass, JWT sessions, AuthMiddleware)
- RBAC (access_service, rbac_middleware, admin routers)
- Audit logging (fire-and-forget, AuditMiddleware, admin router)
- i18n (react-i18next with 5 namespace files)

Phase 2 (Admin Panel & Client Management):
- Admin panel shell (sidebar layout, role guard, 12 pages)
- Redux admin slice with 18 async thunks
- User management (role changes, deactivation)
- Client management (CRUD, brand config, team management)
- Brand config editor (colors, fonts, logos, voice rules)
- Master deck upload & parser (PPTX → HTML → React pipeline)
- Audit log viewer with filters and CSV/JSON export

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-26 15:37:17 +00:00

153 lines
6.2 KiB
Python

from constants.supported_ollama_models import SUPPORTED_OLLAMA_MODELS
from constants.llm import OPENAI_URL
from enums.image_provider import ImageProvider
from enums.llm_provider import LLMProvider
from utils.available_models import (
list_available_anthropic_models,
list_available_google_models,
list_available_openai_compatible_models,
)
from utils.get_env import (
get_anthropic_api_key_env,
get_anthropic_model_env,
get_can_change_keys_env,
get_google_model_env,
get_openai_api_key_env,
get_openai_model_env,
get_pixabay_api_key_env,
get_pexels_api_key_env,
get_comfyui_url_env,
get_comfyui_workflow_env,
)
from utils.get_env import get_google_api_key_env
from utils.get_env import get_ollama_model_env
from utils.get_env import get_custom_llm_api_key_env
from utils.get_env import get_custom_llm_url_env
from utils.get_env import get_custom_model_env
from utils.llm_provider import (
get_llm_provider,
is_custom_llm_selected,
is_ollama_selected,
)
from utils.ollama import pull_ollama_model
from utils.image_provider import (
get_selected_image_provider,
is_image_generation_disabled,
)
async def check_llm_and_image_provider_api_or_model_availability():
can_change_keys = get_can_change_keys_env() != "false"
if not can_change_keys:
if get_llm_provider() == LLMProvider.OPENAI:
openai_api_key = get_openai_api_key_env()
if not openai_api_key:
raise Exception("OPENAI_API_KEY must be provided")
openai_model = get_openai_model_env()
if openai_model:
available_models = await list_available_openai_compatible_models(
OPENAI_URL, openai_api_key
)
if openai_model not in available_models:
print("-" * 50)
print("Available models: ", available_models)
raise Exception(f"Model {openai_model} is not available")
elif get_llm_provider() == LLMProvider.GOOGLE:
google_api_key = get_google_api_key_env()
if not google_api_key:
raise Exception("GOOGLE_API_KEY must be provided")
google_model = get_google_model_env()
if google_model:
available_models = await list_available_google_models(google_api_key)
if google_model not in available_models:
print("-" * 50)
print("Available models: ", available_models)
raise Exception(f"Model {google_model} is not available")
elif get_llm_provider() == LLMProvider.ANTHROPIC:
anthropic_api_key = get_anthropic_api_key_env()
if not anthropic_api_key:
raise Exception("ANTHROPIC_API_KEY must be provided")
anthropic_model = get_anthropic_model_env()
if anthropic_model:
available_models = await list_available_anthropic_models(
anthropic_api_key
)
if anthropic_model not in available_models:
print("-" * 50)
print("Available models: ", available_models)
raise Exception(f"Model {anthropic_model} is not available")
elif is_ollama_selected():
ollama_model = get_ollama_model_env()
if not ollama_model:
raise Exception("OLLAMA_MODEL must be provided")
if ollama_model not in SUPPORTED_OLLAMA_MODELS:
raise Exception(f"Model {ollama_model} is not supported")
print("-" * 50)
print("Pulling model: ", ollama_model)
async for event in pull_ollama_model(ollama_model):
print(event)
print("Pulled model: ", ollama_model)
print("-" * 50)
elif is_custom_llm_selected():
custom_model = get_custom_model_env()
custom_llm_url = get_custom_llm_url_env()
if not custom_model:
raise Exception("CUSTOM_MODEL must be provided")
if not custom_llm_url:
raise Exception("CUSTOM_LLM_URL must be provided")
available_models = await list_available_openai_compatible_models(
custom_llm_url, get_custom_llm_api_key_env() or "null"
)
print("-" * 50)
print("Available models: ", available_models)
if custom_model not in available_models:
raise Exception(f"Model {custom_model} is not available")
# Skip image provider and API key checks if image generation is disabled
if is_image_generation_disabled():
return
# Check for Image Provider and API keys
selected_image_provider = get_selected_image_provider()
if not selected_image_provider:
raise Exception("IMAGE_PROVIDER must be provided")
if selected_image_provider == ImageProvider.PEXELS:
pexels_api_key = get_pexels_api_key_env()
if not pexels_api_key:
raise Exception("PEXELS_API_KEY must be provided")
elif selected_image_provider == ImageProvider.PIXABAY:
pixabay_api_key = get_pixabay_api_key_env()
if not pixabay_api_key:
raise Exception("PIXABAY_API_KEY must be provided")
elif (
selected_image_provider == ImageProvider.GEMINI_FLASH
or selected_image_provider == ImageProvider.NANOBANANA_PRO
):
google_api_key = get_google_api_key_env()
if not google_api_key:
raise Exception("GOOGLE_API_KEY must be provided")
elif (
selected_image_provider == ImageProvider.DALLE3
or selected_image_provider == ImageProvider.GPT_IMAGE_1_5
):
openai_api_key = get_openai_api_key_env()
if not openai_api_key:
raise Exception("OPENAI_API_KEY must be provided")
elif selected_image_provider == ImageProvider.COMFYUI:
comfyui_url = get_comfyui_url_env()
if not comfyui_url:
raise Exception("COMFYUI_URL must be provided")
workflow_json = get_comfyui_workflow_env()
if not workflow_json:
raise Exception("COMFYUI_WORKFLOW must be provided")