model_provider_cache.py 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import json
  2. from enum import Enum
  3. from json import JSONDecodeError
  4. from typing import Optional
  5. from extensions.ext_redis import redis_client
  6. class ProviderCredentialsCacheType(Enum):
  7. PROVIDER = "provider"
  8. MODEL = "provider_model"
  9. LOAD_BALANCING_MODEL = "load_balancing_provider_model"
  10. class ProviderCredentialsCache:
  11. def __init__(self, tenant_id: str, identity_id: str, cache_type: ProviderCredentialsCacheType):
  12. self.cache_key = f"{cache_type.value}_credentials:tenant_id:{tenant_id}:id:{identity_id}"
  13. def get(self) -> Optional[dict]:
  14. """
  15. Get cached model provider credentials.
  16. :return:
  17. """
  18. cached_provider_credentials = redis_client.get(self.cache_key)
  19. if cached_provider_credentials:
  20. try:
  21. cached_provider_credentials = cached_provider_credentials.decode('utf-8')
  22. cached_provider_credentials = json.loads(cached_provider_credentials)
  23. except JSONDecodeError:
  24. return None
  25. return cached_provider_credentials
  26. else:
  27. return None
  28. def set(self, credentials: dict) -> None:
  29. """
  30. Cache model provider credentials.
  31. :param credentials: provider credentials
  32. :return:
  33. """
  34. redis_client.setex(self.cache_key, 86400, json.dumps(credentials))
  35. def delete(self) -> None:
  36. """
  37. Delete cached model provider credentials.
  38. :return:
  39. """
  40. redis_client.delete(self.cache_key)