Skip to main content

A simple, ready-to-use client for testing the SmallWebRTCTransport.

Project description

SmallWebRTC Prebuilt

A simple, ready-to-use client for testing the SmallWebRTCTransport.

This prebuilt client provides basic WebRTC functionality and serves as a lightweight tool to quickly verify transport behavior without needing a custom implementation.

Ideal for development, debugging, and quick prototyping.


📦 Installation & Usage

If you just want to use the prebuilt WebRTC client in your own Python project:

✅ Install from PyPI

pip install pipecat-ai-small-webrtc-prebuilt

🧰 Example Usage

from fastapi import FastAPI
from fastapi.responses import RedirectResponse
from pipecat_ai_small_webrtc_prebuilt.frontend import SmallWebRTCPrebuiltUI

app = FastAPI()

# Mount the frontend at /prebuilt
app.mount("/prebuilt", SmallWebRTCPrebuiltUI)

@app.get("/", include_in_schema=False)
async def root_redirect():
    return RedirectResponse(url="/prebuilt/")

🧪 Try a Sample App

Want to see it in action? Check out our sample app demonstrating how to use this module:

⌨ Development Quick Start

If you want to work on the prebuilt client itself or use it locally in development:

📋 Prerequisites

  • Node.js (for building the client)
  • uv (recommended for Python dependency management)

🔧 Set Up the Environment

  1. Clone the Repository
git clone https://github.com/your-org/small-webrtc-prebuilt.git
cd small-webrtc-prebuilt
  1. Build the Client

The Python package serves a built React client, so you need to build it first:

cd client
npm install
npm run build
cd ..

This creates the client/dist/ directory that the Python package will serve.

  1. Try the Sample App

Now you can test the local package with the sample app:

cd test
uv sync  # Installs dependencies and the local package in editable mode
uv run bot.py

Then open http://localhost:7860 in your browser.

🚀 Publishing

Publishing is automated via GitHub Actions using trusted publishing (no API tokens needed).

Prerequisites

  1. Update the version in pyproject.toml:

    version = "2.0.3"
    
  2. Create a git tag:

    git tag -m v2.0.3 v2.0.3
    git push --tags origin
    

Publishing Process

  1. Go to GitHub Actions in your repository
  2. Select the "publish" workflow
  3. Click "Run workflow"
  4. Enter the git tag (e.g., v2.0.2)
  5. Click "Run workflow"

The workflow will:

  • Build the client (React/Vite)
  • Bundle it into the Python package
  • Build the Python package with version from pyproject.toml
  • Publish to both Test PyPI and PyPI

Testing Before Production

To test publishing without creating a release:

  1. Use the publish-test workflow (publishes to Test PyPI only):

    • Go to GitHub Actions → "publish-test" workflow
    • Click "Run workflow"
    • No git tag needed!
  2. Install from Test PyPI:

    pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple/ pipecat-ai-small-webrtc-prebuilt
    
  3. Test your changes, then use the regular publish workflow for production

Local Build Testing

To test the build locally before publishing:

# Build the client
cd client
npm install
npm run build
cd ..

# Copy client to package
mkdir -p pipecat_ai_small_webrtc_prebuilt/client
cp -r client/dist pipecat_ai_small_webrtc_prebuilt/client/

# Build the package
uv build

# Clean up
rm -rf pipecat_ai_small_webrtc_prebuilt/client

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

pipecat_ai_small_webrtc_prebuilt-2.5.0.tar.gz (474.3 kB view details)

Uploaded Source

Built Distribution

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

pipecat_ai_small_webrtc_prebuilt-2.5.0-py3-none-any.whl (474.3 kB view details)

Uploaded Python 3

File details

Details for the file pipecat_ai_small_webrtc_prebuilt-2.5.0.tar.gz.

File metadata

File hashes

Hashes for pipecat_ai_small_webrtc_prebuilt-2.5.0.tar.gz
Algorithm Hash digest
SHA256 51481506b7b5dff10eff0357ff929cba504a5198c3393697178d2be9895ad9e6
MD5 899b3bf4ef6f6feee082047c2d2d9560
BLAKE2b-256 2c4f40bfc9fc1a13f9b1f2657e292c51ff3e3516c530ca722effdcf342d465d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for pipecat_ai_small_webrtc_prebuilt-2.5.0.tar.gz:

Publisher: publish.yml on pipecat-ai/small-webrtc-prebuilt

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

File details

Details for the file pipecat_ai_small_webrtc_prebuilt-2.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pipecat_ai_small_webrtc_prebuilt-2.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 23b1eee95662a0072d9ee5128b8567108eda10d5a54ad71f279730afbb678bfe
MD5 8aa4bc1002bd22b41cc6bee358f4bfb7
BLAKE2b-256 34581a2e10c1fb7b44e47558cb6c0954e24a60f98afe912fe55c74fdee66f080

See more details on using hashes here.

Provenance

The following attestation bundles were made for pipecat_ai_small_webrtc_prebuilt-2.5.0-py3-none-any.whl:

Publisher: publish.yml on pipecat-ai/small-webrtc-prebuilt

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