You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

bridge.py 3.7KB

1 anno fa
1 anno fa
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. from bot.bot_factory import create_bot
  2. from bridge.context import Context
  3. from bridge.reply import Reply
  4. from common import const
  5. from common.log import logger
  6. from common.singleton import singleton
  7. from config import conf
  8. from translate.factory import create_translator
  9. from voice.factory import create_voice
  10. @singleton
  11. class Bridge(object):
  12. def __init__(self):
  13. self.btype = {
  14. "chat": const.CHATGPT,
  15. "voice_to_text": conf().get("voice_to_text", "openai"),
  16. "text_to_voice": conf().get("text_to_voice", "google"),
  17. "translate": conf().get("translate", "baidu"),
  18. }
  19. # 这边取配置的模型
  20. model_type = conf().get("model") or const.GPT35
  21. if model_type in ["text-davinci-003"]:
  22. self.btype["chat"] = const.OPEN_AI
  23. if conf().get("use_azure_chatgpt", False):
  24. self.btype["chat"] = const.CHATGPTONAZURE
  25. if model_type in ["wenxin", "wenxin-4"]:
  26. self.btype["chat"] = const.BAIDU
  27. if model_type in ["xunfei"]:
  28. self.btype["chat"] = const.XUNFEI
  29. if model_type in [const.QWEN]:
  30. self.btype["chat"] = const.QWEN
  31. if model_type in [const.QWEN_TURBO, const.QWEN_PLUS, const.QWEN_MAX]:
  32. self.btype["chat"] = const.QWEN_DASHSCOPE
  33. if model_type in [const.GEMINI]:
  34. self.btype["chat"] = const.GEMINI
  35. if model_type in [const.ZHIPU_AI]:
  36. self.btype["chat"] = const.ZHIPU_AI
  37. if model_type and model_type.startswith("claude-3"):
  38. self.btype["chat"] = const.CLAUDEAPI
  39. if conf().get("use_linkai") and conf().get("linkai_api_key"):
  40. self.btype["chat"] = const.LINKAI
  41. if not conf().get("voice_to_text") or conf().get("voice_to_text") in ["openai"]:
  42. self.btype["voice_to_text"] = const.LINKAI
  43. if not conf().get("text_to_voice") or conf().get("text_to_voice") in ["openai", const.TTS_1, const.TTS_1_HD]:
  44. self.btype["text_to_voice"] = const.LINKAI
  45. if model_type in ["claude"]:
  46. self.btype["chat"] = const.CLAUDEAI
  47. self.bots = {}
  48. self.chat_bots = {}
  49. # 模型对应的接口
  50. def get_bot(self, typename):
  51. if self.bots.get(typename) is None:
  52. logger.info("create bot {} for {}".format(self.btype[typename], typename))
  53. if typename == "text_to_voice":
  54. self.bots[typename] = create_voice(self.btype[typename])
  55. elif typename == "voice_to_text":
  56. self.bots[typename] = create_voice(self.btype[typename])
  57. elif typename == "chat":
  58. self.bots[typename] = create_bot(self.btype[typename])
  59. elif typename == "translate":
  60. self.bots[typename] = create_translator(self.btype[typename])
  61. return self.bots[typename]
  62. def get_bot_type(self, typename):
  63. return self.btype[typename]
  64. def fetch_reply_content(self, query, context: Context) -> Reply:
  65. return self.get_bot("chat").reply(query, context)
  66. def fetch_voice_to_text(self, voiceFile) -> Reply:
  67. return self.get_bot("voice_to_text").voiceToText(voiceFile)
  68. def fetch_text_to_voice(self, text) -> Reply:
  69. return self.get_bot("text_to_voice").textToVoice(text)
  70. def fetch_translate(self, text, from_lang="", to_lang="en") -> Reply:
  71. return self.get_bot("translate").translate(text, from_lang, to_lang)
  72. def find_chat_bot(self, bot_type: str):
  73. if self.chat_bots.get(bot_type) is None:
  74. self.chat_bots[bot_type] = create_bot(bot_type)
  75. return self.chat_bots.get(bot_type)
  76. def reset_bot(self):
  77. """
  78. 重置bot路由
  79. """
  80. self.__init__()