Trying to make it work in the self chat
All checks were successful
git.cronocide.net/bluebubbles-bot/pipeline/head This commit looks good
All checks were successful
git.cronocide.net/bluebubbles-bot/pipeline/head This commit looks good
This commit is contained in:
parent
1464b23d8c
commit
edab42916b
@ -45,14 +45,17 @@ class PersonaSkill(PersonaBaseSkill) :
|
|||||||
if 'RESPONSE_PREAMBLE' in os.environ.keys() :
|
if 'RESPONSE_PREAMBLE' in os.environ.keys() :
|
||||||
RESPONSE_PREAMBLE = os.environ['RESPONSE_PREAMBLE']
|
RESPONSE_PREAMBLE = os.environ['RESPONSE_PREAMBLE']
|
||||||
if 'CHATGPT_RESPOND_TO_SELF_IN_CHAT' in os.environ.keys() :
|
if 'CHATGPT_RESPOND_TO_SELF_IN_CHAT' in os.environ.keys() :
|
||||||
self.respond_to_self = os.environ['CHATGPT_RESPOND_TO_SELF_IN_CHAT']
|
self.respond_to_self = os.environ['CHATGPT_RESPOND_TO_SELF_IN_CHAT'].split(',')
|
||||||
self.system_prompt = [{'role': 'system', 'content': RESPONSE_PREAMBLE}]
|
self.system_prompt = [{'role': 'system', 'content': RESPONSE_PREAMBLE}]
|
||||||
|
|
||||||
|
|
||||||
def match_intent(self,message: Message) -> Bool :
|
def match_intent(self,message: Message) -> Bool :
|
||||||
# Tag user and bot for API
|
# Tag user and bot for API
|
||||||
if message.meta['isFromMe'] :
|
if message.meta['isFromMe'] :
|
||||||
role = 'assistant'
|
if self.respond_to_self and (len([x for x in self.respond_to_self if x in list(set([message.sender_identifier] + message.recipients))])) > 0 :
|
||||||
|
role = 'user'
|
||||||
|
else :
|
||||||
|
role = 'assistant'
|
||||||
else :
|
else :
|
||||||
role = 'user'
|
role = 'user'
|
||||||
# Record chat messages for context
|
# Record chat messages for context
|
||||||
@ -60,7 +63,9 @@ class PersonaSkill(PersonaBaseSkill) :
|
|||||||
if message.chat_identifier not in self.chat_logs.keys() :
|
if message.chat_identifier not in self.chat_logs.keys() :
|
||||||
self.chat_logs.update({message.chat_identifier: deque([{'role': role, 'content': message.text, 'name': sender}], maxlen=MAX_CHAT_CONTEXT)})
|
self.chat_logs.update({message.chat_identifier: deque([{'role': role, 'content': message.text, 'name': sender}], maxlen=MAX_CHAT_CONTEXT)})
|
||||||
else :
|
else :
|
||||||
self.chat_logs[message.chat_identifier].append({'role': role, 'content': message.text, 'name': sender})
|
if message.text not in [x['content'] for x in self.chat_logs[message.chat_identifier]] :
|
||||||
|
self.chat_logs[message.chat_identifier].append({'role': role, 'content': message.text, 'name': sender})
|
||||||
|
self.log.debug(f'Chat log for {message.chat_identifier}: {list(self.chat_logs[message.chat_identifier])}')
|
||||||
# Don't respond if you've responded already recently
|
# Don't respond if you've responded already recently
|
||||||
if datetime.datetime.now().timestamp() < (self.last_check + BACKOFF_SEC) :
|
if datetime.datetime.now().timestamp() < (self.last_check + BACKOFF_SEC) :
|
||||||
self.log.warn('Responding too fast, not responding again.')
|
self.log.warn('Responding too fast, not responding again.')
|
||||||
@ -72,6 +77,7 @@ class PersonaSkill(PersonaBaseSkill) :
|
|||||||
matches = re.search(trigger, message.text)
|
matches = re.search(trigger, message.text)
|
||||||
if matches :
|
if matches :
|
||||||
self.enabled_chats.append(message.chat_identifier)
|
self.enabled_chats.append(message.chat_identifier)
|
||||||
|
self.chat_logs[message.chat_identifier].pop()
|
||||||
# We are not responding to this chat and have not been asked to.
|
# We are not responding to this chat and have not been asked to.
|
||||||
return False
|
return False
|
||||||
else :
|
else :
|
||||||
@ -82,7 +88,7 @@ class PersonaSkill(PersonaBaseSkill) :
|
|||||||
self.enabled_chats.remove(message.chat_identifier)
|
self.enabled_chats.remove(message.chat_identifier)
|
||||||
return False
|
return False
|
||||||
if message.meta['isFromMe'] :
|
if message.meta['isFromMe'] :
|
||||||
if self.respond_to_self and (self.respond_to_self in list(set([sender] + message.recipients))) :
|
if self.respond_to_self and (len([x for x in self.respond_to_self if x in list(set([message.sender_identifier] + message.recipients))])) > 0 :
|
||||||
return True
|
return True
|
||||||
else :
|
else :
|
||||||
return False
|
return False
|
||||||
|
Loading…
Reference in New Issue
Block a user