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

Example for an asynchronous websocket server #27

Open
moaazsidat opened this issue Mar 11, 2021 · 3 comments
Open

Example for an asynchronous websocket server #27

moaazsidat opened this issue Mar 11, 2021 · 3 comments

Comments

@moaazsidat
Copy link

moaazsidat commented Mar 11, 2021

Hey folks, thanks for putting this together as a useful interface to AWS transcribe.

I'm looking for an example that works with an async websocket server calling AWS transcribe.
The problem I'm running into right now is that handler.handle_events() is a blocking call that prevents processing further messages – here's my code thus far with a FastAPI websocket app:

import json
import typing

from fastapi import FastAPI, WebSocket
from starlette.endpoints import WebSocketEndpoint

from amazon_transcribe.client import TranscribeStreamingClient
from amazon_transcribe.handlers import TranscriptResultStreamHandler
from amazon_transcribe.model import TranscriptEvent

import numpy as np
from scipy.io.wavfile import read, write

app = FastAPI()

"""
Here's an example of a custom event handler you can extend to
process the returned transcription results as needed. This
handler will simply print the text out to your interpreter.
"""
class MyEventHandler(TranscriptResultStreamHandler):
    async def handle_transcript_event(self, transcript_event: TranscriptEvent):
        # This handler can be implemented to handle transcriptions as needed.
        # Here's an example to get started.
        print("LOG: handler called")
        results = transcript_event.transcript.results
        for result in results:
            for alt in result.alternatives:
                print(f"TRANSCRIPT: {alt.transcript}")


@app.websocket_route("/media")
class Transcription(WebSocketEndpoint):

    async def on_connect(self, websocket: WebSocket) -> None:
        await websocket.accept()
        self.transcription_client = TranscribeStreamingClient(region="ca-central-1")
        self.stream = None
        self.handler = None
        self.chunks_np = np.array([])

    async def on_disconnect(self, websocket: WebSocket, close_code: int) -> None:
        print("LOG: disconnect: ")
        await self.stream.input_stream.end_stream()

    async def on_receive(self, websocket: WebSocket, data: typing.Any) -> None:
        message = json.loads(data)

        if message is not None:
            # print("LOG: message received: ", message)
            if self.stream is None and self.handler is None:
                self.stream = await self.transcription_client.start_stream_transcription(
                    language_code="en-US",
                    media_sample_rate_hz=44100,
                    media_encoding="pcm",
                )
                self.handler = MyEventHandler(self.stream.output_stream)

            chunk = message["chunk"]
            chunk_np = np.fromiter(chunk.values(), dtype=np.int16)

            self.chunks_np = np.append(self.chunks_np, chunk_np)

            chunk_bytes = chunk_np.tobytes()

            await self.stream.input_stream.send_audio_event(audio_chunk=chunk_bytes)
            await self.handler.handle_events()

Any guidance as to what's a good way to call handler.handle_events() in a non-blocking manner?

Have tried wrapping the handler.handle_events() in a while loop and invoking that via a background task and that runs into a similar blocking behaviour as well.

@ajay960singh
Copy link

Hey @moaazsidat , were you able to solve for this?

@parikls
Copy link

parikls commented Sep 23, 2021

@ajay960singh handle_events must be scheduled as a task, e.g. asyncio.create_task(self.handler.handle_events())

@Nithin745
Copy link

Hi, I'm trying something similar, not able to crack it. Did you got it working?

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