Skip to content
Cloudflare Docs

Stage Management

This guide explains how to use stage management APIs for Webinar (WebRTC) use cases in Cloudflare RealtimeKit.

Instead of a traditional publish-subscribe model, where a user can publish their media and others can choose to subscribe, RealtimeKit comes with an optional managed configuration. In this managed configuration, a less privileged user can be configured with a default behavior to not publish media. The user can then request permission to be allowed to publish their media, where a privileged user can choose to grant or deny access.

Using RealtimeKit's stage management APIs, a user can perform actions such as:

  • Leave and join stage
  • Manage stage requests and permissions
  • Kick participants

Access the Stage APIs

The stage module can be accessed under the meeting.stage namespace.

console.log("Stage object:", meeting.stage);

Properties

Status

The meeting.stage.status property returns the current stage status of the local user.

console.log("Stage status:", meeting.stage.status);

Possible status values:

  • ON_STAGE - The user is currently on the stage and sharing audio and video.
  • OFF_STAGE - The user is viewing the session but is not on the stage and is not sharing audio or video.
  • REQUESTED_TO_JOIN_STAGE - The user has a pending request to join the stage and share audio and video. This status remains until the host accepts or rejects the request.
  • ACCEPTED_TO_JOIN_STAGE - The host has accepted the user's request to join the stage.

Host Controls

RealtimeKit's stage management APIs allow hosts to receive and manage stage requests as well as leave and join the stage.

Join Stage

This method connects the user to the media room, enabling them to interact with other peers in the meeting.

await meeting.stage.join();

Leave Stage

By employing this method, the user will be disconnected from the media room and subsequently unable to communicate with their peers. Additionally, their audio and video will no longer be visible to others in the room.

await meeting.stage.leave();

Grant Access

A privileged user can grant access to stage for a set of users with the grantAccess method.

await meeting.stage.grantAccess(userIds);

Parameters:

  • userIds (string[]) - Array of user IDs to grant stage access. You can retrieve user IDs using meeting.participants.toArray().map(p => p.userId)

Deny Access

A privileged user can deny access to stage for a set of users with the denyAccess method.

await meeting.stage.denyAccess(userIds);

Parameters:

  • userIds (string[]) - Array of user IDs to deny stage access. You can retrieve user IDs using meeting.participants.toArray().map(p => p.userId)

Kick Users

A privileged user can remove a set of users from stage using the kick method.

await meeting.stage.kick(userIds);

Parameters:

  • userIds (string[]) - Array of user IDs to remove from stage. You can retrieve user IDs using meeting.participants.toArray().map(p => p.userId)

Participant Controls

RealtimeKit's stage management APIs allow participants to request and manage stage access.

Request Access

This method is used to create a new stage request which can be approved by the host. Each user (viewer or host) must call this method in order to join the stage.

When the host calls this method, their status will be updated to ACCEPTED_TO_JOIN_STAGE.

await meeting.stage.requestAccess();

Cancel Access Request

You can call this method to cancel your stage request.

await meeting.stage.cancelRequestAccess();

Events

The meeting.stage module emits the following events:

Stage Access Requests Updated

Emitted when there is an update to stage access requests.

meeting.stage.on("stageAccessRequestUpdate", (data) => {
console.log("Stage access request updated:", data);
});

Alternatively, you can use React hooks to listen for stage updates:

import { useRealtimeKitSelector } from "@cloudflare/realtimekit-react";
// useRealtimeKitSelector hook only works when `RealtimeKitProvider` is used.
const stageStatus = useRealtimeKitSelector((m) => m.stage.status);

Stage Access Request Accepted

Emitted when the host accepts the join stage request or invites a user directly to stage.

meeting.stage.on("acceptPresentRequests", (data) => {
console.log("Present requests accepted:", data);
});

Stage Status Updated

Emitted when the local user's stage status changes.

meeting.stage.on("stageStatusUpdate", (status) => {
console.log("Stage status updated:", status);
});

New Stage Request

Emitted when a new participant requests to join the stage.

meeting.stage.on("newStageRequest", (request) => {
console.log("New stage request:", request);
});

Stage Request Approved

Emitted when a stage request is approved by the host.

meeting.stage.on("stageRequestApproved", (data) => {
console.log("Stage request approved:", data);
});

Stage Request Rejected

Emitted when the host rejects a stage request.

meeting.stage.on("stageRequestRejected", (data) => {
console.log("Stage request rejected:", data);
});