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
idle_timeout_seconds int LiveKit egress idle timeout in seconds (0 uses server defaults)

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.

When starting, the plugin automatically sets lk.publish_on_behalf to the agent participant identity for avatar worker association in LiveKit frontends.

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.3.tar.gz (8.0 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.3-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for livekit_plugins_spatialreal-1.4.3.tar.gz
Algorithm Hash digest
SHA256 9628eb439dc245b2f9adc7f0b13e69dfdd4211ec5048a2b36f42c884e449134f
MD5 d4523bdf37a5eb34bddf955dd925818d
BLAKE2b-256 45b98240cf41d147901f84912db14ab28f5313192f8705bda04dfca9a9e94aac

See more details on using hashes here.

Provenance

The following attestation bundles were made for livekit_plugins_spatialreal-1.4.3.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.3-py3-none-any.whl.

File metadata

File hashes

Hashes for livekit_plugins_spatialreal-1.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e98a916ec93f5ecb5064ca8b99bb5b13a2e113c88e69059cd022917114f2bfd2
MD5 65cc94f36c51ac38a133131d6b4585c6
BLAKE2b-256 42df6081f3aa4119b3af22ccf3ef3b7267e28abff5b4db1867c75d4cd2555f21

See more details on using hashes here.

Provenance

The following attestation bundles were made for livekit_plugins_spatialreal-1.4.3-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