Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

No context when used with Wyoming satellite #124

Open
Edmundas1 opened this issue Jan 29, 2024 · 5 comments
Open

No context when used with Wyoming satellite #124

Edmundas1 opened this issue Jan 29, 2024 · 5 comments

Comments

@Edmundas1
Copy link

When I'm using HA assist pipeline with extended_openai_conversation through Wyoming satellite devices there is no context passed to openai API, I've looked into logs and each request is like completely new request. When I'm using assist chat through HA web interface with the same pipeline, everything works fine.

@LowKey88
Copy link

Yes, i'm aware of this also. @jekalmin any thought about this?

@jekalmin
Copy link
Owner

Thanks for reporting an issue!

In order to use same message history, conversation_id should be passed to ConversationAgent.
It seems Wyoming satellite devices don't pass conversation_id after first conversation.

In my opinion, it's Wyoming satellite devices' responsibility to pass conversation_id because HA web and Esphome devices (m5stack atom echo and esp32-s3-box) have implemented this.

To dig deeper, please add following code in this line and see if conversation_id is None.

print("user_input", user_input, "context", user_input.context.as_dict())

Ideally, conversation_id should be None on the first time, and not None starting from second request.

@LowKey88
Copy link

LowKey88 commented Jan 30, 2024

OK, it's confirmed, the conversation_id is not passed and conversation_id = None all the time of request using Wyoming Satellite

- `user_input: ConversationInput(text='xxx', context=<...>, conversation_id=None, device_id='...', language='*'), context: {'id': '...', 'parent_id': None, 'user_id': None}`
- `user_input: ConversationInput(text='xxx.', context=<...>, conversation_id=None, device_id='...', language='*'), context: {'id': '...', 'parent_id': None, 'user_id': None}`

@Edmundas1
Copy link
Author

Thank you jekalmin and LowKey88, hopefully it'll be fixed at wyoming-satellite or maybe I will switch to ESPHome, though local wake word detection is a plus for Wyoming satellite.

@guinmoon
Copy link

Hi I found a solution that works for me. Now when I use wyoming satellite from docker extended_openai_conversation remembers what we talked about before.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants