From now on Fishjam supports MoQ protocol!Explore our products

Real-time video conferencing, built your way.

Add real-time video conferencing to your app with a few lines of code. Fishjam's Video Conferencing API handles the WebRTC SFU infrastructure — just pick an SDK and start building.

Video conferencing interface preview

Mix and match what you need

Fishjam is a modular real-time media infrastructure. Use one product or combine them depending on your needs.

Rooms & participants

Create and manage video rooms with a single API call. Invite participants, control access with tokens, and let users join from any device.

Media tracks

Send and receive audio, video, and screen share tracks. Subscribe participants to each other's streams and control quality on the fly.

SDKs

React, React Native, and server-side SDKs for video conferencing — ready to drop into your existing stack. No extra config, no infrastructure setup required.

Data channels

Send custom data alongside your media streams. Build chat, reactions, polls, or any real-time feature on top of your video call.

Server-side SDK

Manage rooms, participants, and tokens from your backend. Full control over your conferencing logic without touching WebRTC internals.

Fast to integrate, easy to extend

You're just 3 steps away from a working video call.

01

Create a room

Create your account and grab your API key. Your first room is ready in minutes.

const room = await fishjamClient.createRoom({ type: "conference" });

02

Create a peer

Use the server SDK or REST API to create a room and generate participant tokens.

const { peer, peerToken } = await fishjamClient.createPeer(room.id);

03

Join from any SDK

Connect your React or React Native frontend to the WebRTC video conference. Participants join the room and start streaming - no peer-to-peer complexity, Fishjam's SFU handles routing.

const { joinRoom } = useConnection();
joinRoom({ peerToken });

01

Create a room

Create your account and grab your API key. Your first room is ready in minutes.

const room = await fishjamClient.createRoom({ type: "conference" });

02

Create a peer

Use the server SDK or REST API to create a room and generate participant tokens.

const { peer, peerToken } = await fishjamClient.createPeer(room.id);

03

Join from any SDK

Connect your React or React Native frontend to the WebRTC video conference. Participants join the room and start streaming - no peer-to-peer complexity, Fishjam's SFU handles routing.

const { joinRoom } = useConnection();
joinRoom({ peerToken });

Pick your use case

Edtech
Telehealth
Remote collab
Customer-facing videos

Pay for what you use. Nothing more.

Fishjam uses a usage-based pricing model across all products — from video conferencing and live streaming to AI voice agents. No hidden infrastructure fees. No surprise scaling costs.

Start for free, scale as you grow.

View pricing details

Ready to build?