-
Notifications
You must be signed in to change notification settings - Fork 23
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
API endpoint #14
Comments
Same here, hope some kind of reference document can be published |
Same here. What can be understood from the README.md is that the body of the request should be encoded with JSONLand the paypload should be in PCM audio format. We can also see description of some requests, but no real examples. I suggested that https://github.com/rhasspy/wyoming-faster-whisper is run via tcp:// protocol and tried to send a I would really appreciate any help with sending an example request to any Wyoming server. It's a bit hard for me to understand how it works reading the code. |
I've ended up installing wireshark and capturing packages from HA to piper/whisper. It's indeed TCP (mine code had some errors, I didn't send FIN after write), but the packages looks a bit different from what I assumed from the README.md For example synthesize request described as
And from the Format desciption I would assume that I should set type to "synthesize" and put the So, I guess for any request you can try putting the request under |
Wyoming author here. The first line of the TCP message is JSON with the event type and the size of the "additional data" (JSON) plus the size of the binary payload (PCM audio). The "additional data" was needed because Python has a limit to how many characters can be on a single line, so large JSON messages would be cut off. |
Greetings @synesthesiam! Thank you for your work on the protocol and for taking the time to respond to our request. If you have some more time, I would like to ask one more question. Is there somewhere I can read about the API? I mean, I got the idea with line of JSON, line of additional JSON and PCM audio, the real question for me is the spec of the messages. Is there a place where I can see examples of each request? Otherwise I cannot predict if the data should come in the first line under Also, I'm very curious about the limitation you mentioned "Python has a limit on how many characters can be on a single line". Can you tell me more about this? I've never heard of this before. |
there is no doc, but the events are documented in the source, here in the wyoming sub folder. i just added some private events for my app. i think the limit must be in the server, because everything else in the world can handle big json content |
but the 'api' is read til you get to a lf |
@sdetweil could you be so kind to show me a specific place where this is? I think it would be immensely helpful if such a pointer would be somewhere in readme. Looking at the code I can see events classes, they have class fields that are described in the readme, yet it's not clear how to come up with a working JSON from it.
Thank you, that is basically how it is and that is what I found with Wireshark. At the same time it doesn't help to understand the structure of the messages. I think what I'm asking for could be called an "API specification". Currently, the only way to understand it is to read the code or reverse engineer the server-client connection, and both options are quite time consuming. Having an example for each event type would make the project and protocol much more accessible and easier to work with for new developers. |
ok, you found the wyoming folder here which has the types { type: .... , event-type-property:value...,length:number} and if it is an event w big data, AudioChunk event-type-property the readme here in the wyoming project lists the event specific properties. those are the event object keys (in js) |
my app needs notification of hot word detection(it changes to ui to indicate listening) and then the command string (transcript). i can can use the not detected event too. i connect a js app to the open tcp socket and read the events my manager service sends . |
here is the output of response from describe and from my custom, Hotword and Command events response from Describe() request
my manager sends unsoliticited events to inform the reco process, and the is_final tells me if reco is completed or still in progress
|
Something worth tracking upstream is OpenAPI is planning to add support for streaming json formats formats in 3.2. Mentioning since you're using using openapi as a spec in |
I'm looking to find documentation for using Wyoming Whisper/Piper on a curl request but I can't find what endpoint was used and what data to send to it.
I even look in the code but either I don't understand it or I'm really stupid.
The text was updated successfully, but these errors were encountered: