Skip to main content

Agent Framework plugin for SpatialReal Avatar

Project description

LiveKit Agents Plugin for SpatialReal Avatar

This plugin provides integration with SpatialReal's avatar service for lip-synced avatar rendering in LiveKit voice agents.

Installation

pip install livekit-plugins-spatialreal

Or install from source:

pip install -e .

Configuration

Set the following environment variables:

# Required
SPATIALREAL_API_KEY=your-api-key
SPATIALREAL_APP_ID=your-app-id
SPATIALREAL_AVATAR_ID=your-avatar-id

# Optional
SPATIALREAL_CONSOLE_ENDPOINT=
SPATIALREAL_INGRESS_ENDPOINT=

# LiveKit credentials
LIVEKIT_URL=
LIVEKIT_API_KEY=
LIVEKIT_API_SECRET=

Usage

from livekit.agents import Agent, AgentSession, JobContext, cli, WorkerOptions
from livekit.plugins import spatialreal

class VoiceAssistant(Agent):
    def __init__(self):
        super().__init__(
            instructions="You are a helpful voice assistant."
        )

async def entrypoint(ctx: JobContext):
    await ctx.connect()

    # Configure your pipeline components (VAD, STT, LLM, TTS)
    session = AgentSession(
        vad=vad,
        stt=stt,
        llm=llm,
        tts=tts,
    )

    # Initialize and start the avatar session
    avatar = spatialreal.AvatarSession()
    await avatar.start(session, room=ctx.room)

    # Start the agent session
    await session.start(
        agent=VoiceAssistant(),
        room=ctx.room,
    )

if __name__ == "__main__":
    cli.run_app(WorkerOptions(entrypoint_fnc=entrypoint))

API Reference

AvatarSession

Main class for integrating SpatialReal avatars with LiveKit agents.

Constructor Parameters

Parameter Type Description
api_key str SpatialReal API key (or set SPATIALREAL_API_KEY)
app_id str SpatialReal application ID (or set SPATIALREAL_APP_ID)
avatar_id str Avatar ID to use (or set SPATIALREAL_AVATAR_ID)
console_endpoint_url str Custom console endpoint URL
ingress_endpoint_url str Custom ingress endpoint URL
avatar_participant_identity str LiveKit identity for avatar participant

Methods

  • start(agent_session, room, *, livekit_url, livekit_api_key, livekit_api_secret): Start the avatar session and hook into the agent's audio output.
  • aclose(): Clean up avatar session resources.

SpatialRealException

Exception raised for SpatialReal-related errors.

How It Works

  1. The plugin intercepts TTS audio output from the agent session
  2. Audio frames are forwarded to SpatialReal's avatar service
  3. SpatialReal generates lip-synced video and audio
  4. The avatar joins the LiveKit room and publishes the synchronized streams

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

livekit_plugins_spatialreal-1.4.0.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

livekit_plugins_spatialreal-1.4.0-py3-none-any.whl (7.6 kB view details)

Uploaded Python 3

File details

Details for the file livekit_plugins_spatialreal-1.4.0.tar.gz.

File metadata

File hashes

Hashes for livekit_plugins_spatialreal-1.4.0.tar.gz
Algorithm Hash digest
SHA256 73cb81def7e7c59928146a2e37649c022474aebe563cfec43b4b9af9f7640958
MD5 49697c643626cd08130818338f71f1ac
BLAKE2b-256 fd20eae62fc1119507c062e0580247ace49c3768ea388cbfcfd39b404bfa03ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for livekit_plugins_spatialreal-1.4.0.tar.gz:

Publisher: publish.yml on spatialwalk/livekit-plugins-spatialreal

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file livekit_plugins_spatialreal-1.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for livekit_plugins_spatialreal-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c9cad9384df5acbfe6b18b826765161eca1ca45825012710259ef201e90a0ccb
MD5 26ab2b2fd1f57d7a2d554f02b5eafd92
BLAKE2b-256 a5daa0d67f26732614cd62ab6ade596ce4a22cff7d234f469e5b7dec995f67f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for livekit_plugins_spatialreal-1.4.0-py3-none-any.whl:

Publisher: publish.yml on spatialwalk/livekit-plugins-spatialreal

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page