Added onboarding progress tracking & landing page
This commit is contained in:
109
backend/api/onboarding_utils/api_key_management_service.py
Normal file
109
backend/api/onboarding_utils/api_key_management_service.py
Normal file
@@ -0,0 +1,109 @@
|
||||
"""
|
||||
API Key Management Service
|
||||
Handles API key operations for onboarding.
|
||||
"""
|
||||
|
||||
import time
|
||||
from typing import Dict, Any
|
||||
from fastapi import HTTPException
|
||||
from loguru import logger
|
||||
|
||||
from services.api_key_manager import APIKeyManager
|
||||
from services.validation import check_all_api_keys
|
||||
|
||||
class APIKeyManagementService:
|
||||
"""Service for handling API key management operations."""
|
||||
|
||||
def __init__(self):
|
||||
self.api_key_manager = APIKeyManager()
|
||||
# Simple cache for API keys
|
||||
self._api_keys_cache = None
|
||||
self._cache_timestamp = 0
|
||||
self.CACHE_DURATION = 30 # Cache for 30 seconds
|
||||
|
||||
async def get_api_keys(self) -> Dict[str, Any]:
|
||||
"""Get all configured API keys (masked)."""
|
||||
current_time = time.time()
|
||||
|
||||
# Return cached result if still valid
|
||||
if self._api_keys_cache and (current_time - self._cache_timestamp) < self.CACHE_DURATION:
|
||||
logger.debug("Returning cached API keys")
|
||||
return self._api_keys_cache
|
||||
|
||||
try:
|
||||
self.api_key_manager.load_api_keys() # Load keys from environment
|
||||
api_keys = self.api_key_manager.api_keys # Get the loaded keys
|
||||
|
||||
# Mask the API keys for security
|
||||
masked_keys = {}
|
||||
for provider, key in api_keys.items():
|
||||
if key:
|
||||
masked_keys[provider] = "*" * (len(key) - 4) + key[-4:] if len(key) > 4 else "*" * len(key)
|
||||
else:
|
||||
masked_keys[provider] = None
|
||||
|
||||
result = {
|
||||
"api_keys": masked_keys,
|
||||
"total_providers": len(api_keys),
|
||||
"configured_providers": [k for k, v in api_keys.items() if v]
|
||||
}
|
||||
|
||||
# Cache the result
|
||||
self._api_keys_cache = result
|
||||
self._cache_timestamp = current_time
|
||||
|
||||
return result
|
||||
except Exception as e:
|
||||
logger.error(f"Error getting API keys: {str(e)}")
|
||||
raise HTTPException(status_code=500, detail="Internal server error")
|
||||
|
||||
async def get_api_keys_for_onboarding(self) -> Dict[str, Any]:
|
||||
"""Get all configured API keys for onboarding (unmasked)."""
|
||||
try:
|
||||
self.api_key_manager.load_api_keys() # Load keys from environment
|
||||
api_keys = self.api_key_manager.api_keys # Get the loaded keys
|
||||
|
||||
# Return actual API keys for onboarding pre-filling
|
||||
result = {
|
||||
"api_keys": api_keys,
|
||||
"total_providers": len(api_keys),
|
||||
"configured_providers": [k for k, v in api_keys.items() if v]
|
||||
}
|
||||
|
||||
return result
|
||||
except Exception as e:
|
||||
logger.error(f"Error getting API keys for onboarding: {str(e)}")
|
||||
raise HTTPException(status_code=500, detail="Internal server error")
|
||||
|
||||
async def save_api_key(self, provider: str, api_key: str, description: str = None) -> Dict[str, Any]:
|
||||
"""Save an API key for a provider."""
|
||||
try:
|
||||
success = self.api_key_manager.save_api_key(provider, api_key)
|
||||
|
||||
if success:
|
||||
return {
|
||||
"message": f"API key for {provider} saved successfully",
|
||||
"provider": provider,
|
||||
"status": "saved"
|
||||
}
|
||||
else:
|
||||
raise HTTPException(status_code=400, detail=f"Failed to save API key for {provider}")
|
||||
except HTTPException:
|
||||
raise
|
||||
except Exception as e:
|
||||
logger.error(f"Error saving API key: {str(e)}")
|
||||
raise HTTPException(status_code=500, detail="Internal server error")
|
||||
|
||||
async def validate_api_keys(self) -> Dict[str, Any]:
|
||||
"""Validate all configured API keys."""
|
||||
try:
|
||||
validation_results = check_all_api_keys(self.api_key_manager)
|
||||
|
||||
return {
|
||||
"validation_results": validation_results.get('results', {}),
|
||||
"all_valid": validation_results.get('all_valid', False),
|
||||
"total_providers": len(validation_results.get('results', {}))
|
||||
}
|
||||
except Exception as e:
|
||||
logger.error(f"Error validating API keys: {str(e)}")
|
||||
raise HTTPException(status_code=500, detail="Internal server error")
|
||||
Reference in New Issue
Block a user