• Townie
    AI
  • Blog
  • Docs
  • Pricing
  • We’re hiring!
Log inSign up
svaponi

svaponi

hello-realtime

Remix of jubertioai/hello-realtime
Public
Like
hello-realtime
Home
Code
4
frontend
1
routes
5
README.md
H
main.tsx
Branches
1
Pull requests
Remixes
History
Environment variables
Val Town is a collaborative website to build and scale JavaScript apps.
Deploy APIs, crons, & store data – all from the browser, and deployed in milliseconds.
Sign up now
Code
/
README.md
Code
/
README.md
Search
…
README.md

hello-realtime

Hello Realtime is a OpenAI Realtime app that supports both WebRTC and SIP (telephone) users. You can access the app via WebRTC at hello-realtime.val.run, or via SIP by calling 425-800-0042.

This demo shows off the new SIP API, the new all-in-one WebRTC API, and the new server-side websocket interface.

If you remix the app, you'll just need to pop in your own OPENAI_API_KEY (from platform.openai.com), and if you want SIP, the OPENAI_SIGNING_SECRET.

Architecture

  1. WebRTC Flow:
    • Browser connects to frontend
    • creates WebRTC offer
    • /rtc endpoint handles SDP negotiation with OpenAI
    • observer established to monitor session
  2. SIP Flow:
    • Phone calls triggers webhook
    • /sip endpoint verifies webhook and accepts call
    • observer established to monitor session

API Endpoints

  • GET / - serves the WebRTC-based app
  • POST /rtc - creates a new WebRTC-based Realtime API session
    • Supports optional model URL parameter to override the default model
    • Example: POST /rtc?model=gpt-4o-realtime-preview
  • POST /sip - handles an incoming Realtime API SIP call
  • POST /observer - internal endpoint to establish a Realtime API websocket for session control

Project Structure

β”œβ”€β”€ frontend/     
β”‚   └── index.html          # HTML/JS application for WebRTC
β”œβ”€β”€ main.tsx                # Main entrypoint for the val.town app
└── routes/
    |
    β”œβ”€β”€ agent.ts            # Realtime API session configuration and tools
    β”œβ”€β”€ observer.ts         # Server-side session control for SIP & WebRTC
    β”œβ”€β”€ rtc.ts              # WebRTC session setup
    β”œβ”€β”€ sip.ts              # SIP webhook handling and session setup
    └── utils.ts            # Various HTTP helpers

File Links

  • frontend/index.html
  • main.tsx
  • routes/agent.ts
  • routes/observer.ts
  • routes/rtc.ts
  • routes/sip.ts
  • routes/utils.ts
Get started with a template:
FeaturesVersion controlCode intelligenceCLI
Use cases
TeamsAI agentsSlackGTM
DocsShowcaseTemplatesNewestTrendingAPI examplesNPM packages
PricingNewsletterBlogAboutCareers
We’re hiring!
Brandhi@val.townStatus
X (Twitter)
Discord community
GitHub discussions
YouTube channel
Bluesky
Open Source Pledge
Terms of usePrivacy policyAbuse contact
Β© 2025 Val Town, Inc.