Skip to the content.

V2 Python example

This code skeleton demonstrates how to connect and send audio and receive transcriptions using Juvoly WebSocket API.

#!/usr/bin/env python3

import asyncio
import json

import requests
import websockets # requires websockets-10.0 or later

api_key = <api key>
client_id = <client id>
audio_file_path = <audio file path>
model = "generic"

def get_session_id():
    url = "https://services.juvoly.nl/api/v2/rest/session"
    headers = {
        "X-Juvoly-Api-Key": api_key,
        "X-Juvoly-Client-Id": client_id,
        "Content-Type": "application/json"
    }
    response = requests.post(url, headers=headers, json={})
    response.raise_for_status()
    return response.json().get('sessionId', None)

async def read(websocket):
    while True:
        response = await websocket.recv()
        response_data = json.loads(response)
        if response_data.get("type") == "transcript":
            print("Received:", response_data.get("utterance"))

async def write(websocket):
    with open(audio_file_path, 'rb') as audio_stream:
        while chunk := audio_stream.read(10000):
            await websocket.send(chunk)

async def connect(session_id):
    websocket_url = f"wss://services.juvoly.nl/api/v2/socket/{model}"
    async with websockets.connect(websocket_url, subprotocols=["v2.juvoly", client_id, session_id]) as websocket:
        ready_message = await websocket.recv()
        if json.loads(ready_message).get("type") == "ready":
            write_task = asyncio.create_task(write(websocket))
            read_task = asyncio.create_task(read(websocket))
            await asyncio.gather(write_task, read_task)

if __name__ == "__main__":
    session_id = get_session_id()
    asyncio.run(connect(session_id))