How do I use co-host token authentication?
Using co-host authentication requires app logic changes. Ensure that you read this article before enabling this function.
Co-host authentication applies to scenarios where the channel profile is set to
LIVE_BROADCASTING
.
Understand the tech
Co-host authentication is the means by which the SDK authenticates whether a user has the privilege to publish streams in a live streaming channel.
This function guarantees that only authorized users can publish streams in a channel and prevents illegal users from deliberately disrupting a streaming session.
Prerequisites
Before proceeding, ensure that your app meets the following requirements:
- Uses the Agora Video SDK v2.1.0 or later.
- Uses only token-based authentication on all app clients to authenticate users. For details, see Upgrade authentication mechanism.
Implementation
1. Modify the parameter setting
This section introduces how to set the role parameter when generating a token using C++ as an example. The principles and goals are the same if you are using another programming language.
Parameter | Description |
---|---|
role | The publishing privilege of the user:
|
2. Change the app logic
Refer to the following steps to authenticate whether a user has the publishing privilege (in scenarios where an audience member wants to become a host:
- Before joining a channel, the app client applies for a token with the privilege of a subscriber. The app server generates a token and passes it to the app client.
- The app client calls
joinChannel
and passes the token to the SDK. - Before changing the user role, the app client applies for a token with the privilege of a publisher. The app client generates a second toke, and passes it to the app client.
- The app client calls
renewToken
and passes the new token to the SDK. - The app client calls
setClientRole
to change the user role from an audience member to a host. The Agora server authenticates the token when the app client callssetClientRole
. If the token is generated with the privilege of a publisher, the app client can publish a stream.
If the user wants to switch from a host to an audience member, repeat steps 3 to 5. Apply for a token with the privilege of an audience, call
renewToken
on the app client, and then callsetClientRole
.Once the token expires, you need to generate a new token on the app server and call
renewToken
to pass the new token to the SDK. The new token also has a service validity period.
3. Enable co-host authentication
Refer to the following steps to enable this function in Agora Console:
- Log on to Agora Console. Under Projects, choose a project for which you want to enable co-host authentication, click the Edit icon, and enter the Edit Project page.
- In the Features area, click Enable authentication.
- Follow the on-screen instructions to know more about this function, check the box, and click Enable.
Co-host authentication takes effect in 5 minutes.
Once you have enabled co-host authentication, a user using your app must meet both of the following requirements to publish streams in a channel:
- The user role in
setClientRole
is set asBROADCASTER
. - The user joins the channel with a token that has the privilege of a publisher (by setting the
role
parameter in thebuildToken
method asRole_Publisher
).
Reference
1. Suppose a user takes the role of broadcaster. After I enable co-host authentication, will the user be able to publish streams?
Answer: Yes. After the token expires, you need to generate a new token with the privilege of a publisher, and call renewToken to pass the new token to the SDK.
2. Suppose a user takes the role of audience. After I enable co-host authentication, what should I do if this user wants to switch to broadcaster and publish streams?
Answer: Once co-host authentication is enabled, a user needs to meet both of the following requirements to publish streams:
- The user role in
setClientRole
is set asBROADCASTER
. - The user joins the channel with a token that has the privilege of a publisher (by setting the
role
parameter in thebuildToken
method asRole_Publisher
).
Therefore, for an audience member to become a host and publish streams, you need to follow steps in Change the app logic: generate a token with the privilege of a publisher, call renewToken
to pass the new token to the SDK, and then call setClientRole
to change the user role to broadcaster.