Skip to main content

How can a host change the role of a remote user?

Introduction

In a live interactive streaming channel, the host can invite an audience to take on the role of co-host, or change role back to audience.

You can implement this function by combining the following features:

  • Signaling and channel attributes using methods from the Agora Signaling SDK.
  • Setting the user role using methods from the Agora Video SDK.

Implementation

Before proceeding, ensure that you have integrated both the Agora Signaling SDK and Video SDK in your project. For how to integrate these SDKs, see the following guides:

The basic API call sequence is as follows:

Refer to the detailed steps for implementation:

  1. The host calls sendMessage to send a peer-to-peer message that invites an audience to take on the role of co-host.
  2. The audience receives the invitation message in the onMessageReceived callback.
  3. The audience calls setClientRole to change the user role to CLIENT_ROLE_BROADCASTER.
  4. After successfully changing the user role, the audience receives the onClientRoleChanged callback, and becomes a co-host.
  5. The new co-host calls addOrUpdateChannelAttributes to notify the role change to all users in the channel.
  6. The host receives the onAttributesUpdated callback, and starts co-hosting with the new co-host.

To change a co-host back to an audience, follow the same steps, except when calling setClientRole, set the user role as CLIENT_ROLE_AUDIENCE.

Relative methods in different programming languages

The methods mentioned in this article are in Java. Refer to the following table if you are programming in a different language:

Java/C++Objective-CJavaScript
sendMessageToPeersendMessagesendMessage
onMessageReceivedmessageReceivedMessageFromPeer
setClientRolesetClientRolesetClientRole
onClientRoleChangeddidClientRoleChangedClient.on("client-role-changed")
addOrUpdateChannelAttributesaddOrUpdateChannelAttributesaddOrUpdateChannelAttributes
onAttributesUpdatedattributeUpdateAttributesUpdated
vundefined