tti.py 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import base64
  2. from typing import Dict
  3. from openai import OpenAI
  4. from common.config.tokenizer_manage_config import TokenizerManage
  5. from common.utils.common import bytes_to_uploaded_file
  6. from knowledge.models import FileSourceType
  7. # from dataset.serializers.file_serializers import FileSerializer
  8. from models_provider.base_model_provider import MaxKBBaseModel
  9. from models_provider.impl.base_tti import BaseTextToImage
  10. from oss.serializers.file import FileSerializer
  11. def custom_get_token_ids(text: str):
  12. tokenizer = TokenizerManage.get_tokenizer()
  13. return tokenizer.encode(text)
  14. class XinferenceTextToImage(MaxKBBaseModel, BaseTextToImage):
  15. api_base: str
  16. api_key: str
  17. model: str
  18. params: dict
  19. def __init__(self, **kwargs):
  20. super().__init__(**kwargs)
  21. self.api_key = kwargs.get('api_key')
  22. self.api_base = kwargs.get('api_base')
  23. self.model = kwargs.get('model')
  24. self.params = kwargs.get('params')
  25. @staticmethod
  26. def is_cache_model():
  27. return False
  28. @staticmethod
  29. def new_instance(model_type, model_name, model_credential: Dict[str, object], **model_kwargs):
  30. optional_params = {'params': {'size': '1024x1024', 'quality': 'standard', 'n': 1}}
  31. for key, value in model_kwargs.items():
  32. if key not in ['model_id', 'use_local', 'streaming']:
  33. optional_params['params'][key] = value
  34. return XinferenceTextToImage(
  35. model=model_name,
  36. api_base=model_credential.get('api_base'),
  37. api_key=model_credential.get('api_key'),
  38. **optional_params,
  39. )
  40. def check_auth(self):
  41. self.generate_image('生成一个小猫图片')
  42. def generate_image(self, prompt: str, negative_prompt: str = None):
  43. chat = OpenAI(api_key=self.api_key, base_url=self.api_base)
  44. res = chat.images.generate(model=self.model, prompt=prompt, response_format='b64_json', **self.params)
  45. file_urls = []
  46. # 临时文件
  47. for img in res.data:
  48. file_urls.append(base64.b64decode(img.b64_json))
  49. return file_urls