Skip to content

Commit

Permalink
Merge pull request zhayujie#1167 from zhayujie/feature-app-market
Browse files Browse the repository at this point in the history
feature:  support online knowledge base
  • Loading branch information
zhayujie committed May 29, 2023
2 parents f1a00d5 + 50e44db commit c29d391
Show file tree
Hide file tree
Showing 6 changed files with 83 additions and 1 deletion.
5 changes: 5 additions & 0 deletions bot/bot_factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,9 @@ def create_bot(bot_type):
from bot.chatgpt.chat_gpt_bot import AzureChatGPTBot

return AzureChatGPTBot()

elif bot_type == const.LINKAI:
from bot.linkai.link_ai_bot import LinkAIBot
return LinkAIBot()

raise RuntimeError
72 changes: 72 additions & 0 deletions bot/linkai/link_ai_bot.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
from bot.bot import Bot
from bridge.context import ContextType
from bridge.reply import Reply, ReplyType
from common.log import logger
from bridge.context import Context
from bot.chatgpt.chat_gpt_session import ChatGPTSession
from bot.session_manager import SessionManager
from config import conf
import requests
import time

class LinkAIBot(Bot):

# authentication failed
AUTH_FAILED_CODE = 401

def __init__(self):
self.base_url = "https://api.link-ai.chat/v1"
self.sessions = SessionManager(ChatGPTSession, model=conf().get("model") or "gpt-3.5-turbo")

def reply(self, query, context: Context = None) -> Reply:
return self._chat(query, context)

def _chat(self, query, context, retry_count=0):
if retry_count >= 2:
# exit from retry 2 times
logger.warn("[LINKAI] failed after maximum number of retry times")
return Reply(ReplyType.ERROR, "请再问我一次吧")

try:
session_id = context["session_id"]

session = self.sessions.session_query(query, session_id)

# remove system message
if session.messages[0].get("role") == "system":
session.messages.pop(0)

# load config
app_code = conf().get("app_code")
app_market_api_key = conf().get("app_market_api_key")
logger.info(f"[LINKAI] query={query}, app_code={app_code}")

body = {
"appCode": app_code,
"messages": session.messages
}
headers = {"Authorization": "Bearer " + app_market_api_key}

# do http request
res = requests.post(url=self.base_url + "/chat/completion", json=body, headers=headers).json()

if not res or not res["success"]:
if res.get("code") == self.AUTH_FAILED_CODE:
logger.exception(f"[LINKAI] please check your app_market_api_key, res={res}")
return Reply(ReplyType.ERROR, "请再问我一次吧")
else:
# retry
time.sleep(2)
logger.warn(f"[LINKAI] do retry, times={retry_count}")
return self._chat(query, context, retry_count + 1)
# execute success
reply_content = res["data"]["content"]
logger.info(f"[LINKAI] reply={reply_content}")
self.sessions.session_reply(reply_content, session_id)
return Reply(ReplyType.TEXT, reply_content)
except Exception as e:
logger.exception(e)
# retry
time.sleep(2)
logger.warn(f"[LINKAI] do retry, times={retry_count}")
return self._chat(query, context, retry_count + 1)
2 changes: 2 additions & 0 deletions bridge/bridge.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ def __init__(self):
self.btype["chat"] = const.OPEN_AI
if conf().get("use_azure_chatgpt", False):
self.btype["chat"] = const.CHATGPTONAZURE
if conf().get("app_market_api_key") and conf().get("app_code"):
self.btype["chat"] = const.LINKAI
self.bots = {}

def get_bot(self, typename):
Expand Down
1 change: 0 additions & 1 deletion channel/wechat/wechat_channel.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@
from config import conf, get_appdata_dir
from lib import itchat
from lib.itchat.content import *
from plugins import *


@itchat.msg_register([TEXT, VOICE, PICTURE, NOTE])
Expand Down
1 change: 1 addition & 0 deletions common/const.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
CHATGPT = "chatGPT"
BAIDU = "baidu"
CHATGPTONAZURE = "chatGPTOnAzure"
LINKAI = "linkai"

VERSION = "1.3.0"
3 changes: 3 additions & 0 deletions config.py
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,9 @@
"appdata_dir": "", # 数据目录
# 插件配置
"plugin_trigger_prefix": "$", # 规范插件提供聊天相关指令的前缀,建议不要和管理员指令前缀"#"冲突
# 应用市场配置
"app_market_api_key": "",
"app_code": ""
}


Expand Down

0 comments on commit c29d391

Please sign in to comment.