2023-03-10 15:45:38 +00:00
|
|
|
import aiohttp
|
|
|
|
import json
|
|
|
|
import asyncio
|
|
|
|
from log import getlogger
|
|
|
|
# api_endpoint = "http://localhost:3000/conversation"
|
|
|
|
logger = getlogger()
|
|
|
|
|
|
|
|
|
|
|
|
class BingBot:
|
2023-04-13 13:31:11 +00:00
|
|
|
def __init__(self, session: aiohttp.ClientSession, bing_api_endpoint: str, jailbreakEnabled: bool = False):
|
2023-03-10 15:45:38 +00:00
|
|
|
self.data = {
|
2023-03-17 23:20:55 +00:00
|
|
|
'clientOptions.clientToUse': 'bing',
|
2023-03-10 15:45:38 +00:00
|
|
|
}
|
|
|
|
self.bing_api_endpoint = bing_api_endpoint
|
|
|
|
|
2023-04-13 13:31:11 +00:00
|
|
|
self.session = session
|
2023-04-10 02:52:18 +00:00
|
|
|
|
2023-03-17 23:20:55 +00:00
|
|
|
self.jailbreakEnabled = jailbreakEnabled
|
|
|
|
|
|
|
|
if self.jailbreakEnabled:
|
2023-04-10 02:52:18 +00:00
|
|
|
self.data['jailbreakConversationId'] = json.dumps(True)
|
2023-03-17 23:20:55 +00:00
|
|
|
|
2023-03-10 15:45:38 +00:00
|
|
|
async def ask_bing(self, prompt) -> str:
|
|
|
|
self.data['message'] = prompt
|
2023-04-13 13:31:11 +00:00
|
|
|
max_try = 2
|
2023-04-10 02:52:18 +00:00
|
|
|
while max_try > 0:
|
|
|
|
try:
|
2023-04-13 13:31:11 +00:00
|
|
|
resp = await self.session.post(url=self.bing_api_endpoint, json=self.data, timeout=120)
|
2023-04-10 02:52:18 +00:00
|
|
|
status_code = resp.status
|
|
|
|
body = await resp.read()
|
|
|
|
if not status_code == 200:
|
|
|
|
# print failed reason
|
|
|
|
logger.warning(str(resp.reason))
|
|
|
|
max_try = max_try - 1
|
|
|
|
# print(await resp.text())
|
|
|
|
await asyncio.sleep(2)
|
|
|
|
continue
|
|
|
|
json_body = json.loads(body)
|
|
|
|
if self.jailbreakEnabled:
|
|
|
|
self.data['jailbreakConversationId'] = json_body['jailbreakConversationId']
|
|
|
|
self.data['parentMessageId'] = json_body['messageId']
|
|
|
|
else:
|
|
|
|
self.data['conversationSignature'] = json_body['conversationSignature']
|
|
|
|
self.data['conversationId'] = json_body['conversationId']
|
|
|
|
self.data['clientId'] = json_body['clientId']
|
|
|
|
self.data['invocationId'] = json_body['invocationId']
|
|
|
|
return json_body['response']
|
|
|
|
except Exception as e:
|
|
|
|
logger.error("Error Exception", exc_info=True)
|
2023-04-13 05:41:47 +00:00
|
|
|
|
|
|
|
|
2023-04-10 02:52:18 +00:00
|
|
|
return "Error, please retry"
|