Skip to main content

Secure authentication with tokens

To enhance communication security, Interactive Whiteboard uses tokens for user authentication.

The Interactive Whiteboard has three types of tokens: SDK Token, Room Token, and Task Token, in descending order of granted permissions. Each token can be assigned to an admin, writer, or reader role. These tokens must be issued from your app server.

SDK Token

An SDK Token is linked with a whiteboard project in Agora Console and grants the most permissions. With an SDK Token, a user can get access to every room and file-conversion task under the linked project. The permissions granted by an SDK Token in a specific role are as follows:

Permissionsadmin SDK Tokenwriter SDK Tokenreader SDK Token
Create a room
Join a room in interactive mode
Join a room in read-only mode
Get a list of rooms
Get room information
Disable a room
Take a screenshot for a specific scene
Take screenshots for a scene directory
Get a list of scene paths in a room
Add a scene
Switch to a scene
Start a file-conversion task
Generate a Room Token for an equal or inferior role (for example, an admin SDK Token can generate an admin, writer, or reader Room Token)
Generate a Task Token for an equal or inferior role (for example, an admin SDK Token can generate an admin, writer, or reader Task Token)

Exposure of SDK Tokens may cause security risks because they grant a large number of permissions. Agora recommends the following precautions:

  • Do not send SDK Tokens to your app clients, save them in a database or write them in a configuration file. You should issue them from your app server only when necessary.
  • Do not issue a permanent SDK Token. You should set a validity period according to your app scenario.

Room Token

A Room Token is linked with a room under a whiteboard project in Agora Console. With a Room Token, a user can get access to the linked room. The permissions granted by a Room Token in a specific role are as follows:

Permissionsadmin Room Tokenwriter Room Tokenreader Room Token
Join the room in interactive mode
Join the room in read-only mode
Get information about the room
Disable the room
Take a screenshot for a specific scene
Take screenshots for a scene directory
Get a list of scene paths in the room
Add a scene in the room
Switch to a scene in the room

Task Token

A Task Token is linked with a file-conversion task under a whiteboard project in Agora Console. With a Task Token, a user can get access to the linked task. The permissions granted by a Task Token in a specific role are as follows:

Permissionsadmin Task Tokenwriter Task Tokenreader Task Token
Query the progress of the file-conversion task

Generate a token

You can generate a token for the Interactive Whiteboard through one of the following methods:

This method can only generate a permanent admin SDK Token. Do not send this token to your app clients; otherwise, there may be a risk of exposure.

When generating a token, pass in the following parameters:

  • A pair of access keys (AK and SK)
  • The role of the token
  • The validity period of the token
  • The Room UUID (for Room Tokens only)
  • The Task UUID (for Task Tokens only)

Get access keys

The access keys consist of an AK (Access Key) and an SK (Secret Key). Follow these steps to get the access keys:

  1. On the Project Management page in Agora Console, find the whiteboard project and click Edit.
  2. On the Edit Project page, find Whiteboard and click Config.
  3. On the Whiteboard Configuration page, find AK and SK. Click the eye icons on the right to copy the AK and SK, respectively, to a secure location.

Unexpected exposure of these access keys can cause severe security problems. To enhance security, Agora recommends the following precautions:

  • Do not send the access keys to your app clients or hard-code the access keys in your app. Ensure that only your app server is allowed to read the access keys from the configuration file.
  • If you believe there may be a risk that your access keys have been exposed, contact support@agora.io to get new access keys.

Set token role

A token can be assigned to an admin, writer, or reader role. The permissions granted by each token role are described in Introduction.

To enhance security, Agora recommends the following precautions:

  • Avoid sending tokens that grant a lot of permissions to your app clients.
  • When it is necessary to send a token to an app client, do not use tokens that grant more permissions than are needed in your app scenario.

Set the validity period

Token validity periods are set as positive integers in milliseconds. You can get the expiration time by adding the validity period and the UTC time when the token was generated. Once a token expires, a user cannot use it to join a room or access the Interactive Whiteboard. To ensure availability, you should generate new tokens on your app server in a timely manner.

If a user uses a token to join a room and the token expires while the user is still in the room, the user will not be kicked out of the room.

Not setting the validity period or setting it to 0 generates a permanent Token.

A permanent Token may cause security risks for your app service. If an illegal user gets a permanent token that grants a lot of permissions, they could use it to disrupt or damage your app system. The only way to invalidate a token is to disable the access keys used to generate it, but this action has significant side effects. Therefore, Agora recommends that you estimate the maximum amount of time a token will be used on app clients based on your app scenario and set this as the validity period.

Get a Room UUID

To generate a Room Token, you need to pass in the Room UUID, the unique identifier of a whiteboard room, so that the Room Token is linked with the room. Follow these steps to get a Room UUID:

  • If the room has been created, call the Interactive Whiteboard RESTful API to get a list of rooms. You can get the corresponding Room UUID in the response body if the request succeeds.
  • If the room has not been created, call the Interactive Whiteboard RESTful API to create a room. You can get the corresponding Room UUID in the response body if the request succeeds.

If you call the Interactive Whiteboard RESTful API to generate a Room Token, the SDK Token in the request header must be the same as that used to create the room.

If you generate the Room Token by adding code on the app server, the access keys passed in must be the same as those used to generate the SDK Token for creating the room.

Get a Task UUID

To generate a Task Token, you need to pass in the Task UUID, the unique identifier of a file-conversion task, so that the Task Token is linked with the task.

To get a Task UUID, call the Interactive Whiteboard RESTful API to start a file-conversion task. You can get the Task UUID in the response body if the request succeeds.

Use a Token

When your app client or server uses a token to access the Interactive Whiteboard, the Agora server needs to verify its corresponding permissions.

The following examples explain how tokens are used in this process:

Example 1: An app client requests to join a room

  1. The app server calls the Interactive Whiteboard RESTful API or uses code to generate an SDK Token.
  2. The app server uses the SDK Token to call the Interactive Whiteboard RESTful API to create a room.
  3. The Agora server receives the request from the app server and verifies the corresponding permissions. If verification passes and the room is created, the Agora server sends a successful response to the app server.
  4. The app server reads the Room UUID in the response and calls the Interactive Whiteboard RESTful API or uses code to generate the Room Token.
  5. The app server sends the Room Token and Room UUID to the app client.
  6. The app client uses the Room Token and Room UUID to join the room.
  7. The Agora server receives the request from the app client and verifies the corresponding permissions. If verification passes, the app client can join the room and use the corresponding features.

Example 2: An app client requests to start a file-conversion task

  1. The app server calls the Interactive Whiteboard RESTful API or uses code to generate an SDK Token.

  2. The app server uses the SDK Token to call the Interactive Whiteboard RESTful API to create a file-conversion task.

  3. The Agora server receives the request from the app server and verifies the corresponding permissions. If verification passes and the task is created, the Agora server sends a successful response to the app server.

  4. The app server reads the Task UUID in the response and calls the Interactive Whiteboard RESTful API or uses code to generate the Task Token.

  5. The app server uses the Task Token and Task UUID to call the Interactive Whiteboard RESTful API to query the progress of the conversion task.

  6. The Agora server receives the request from the app client and verifies the corresponding permissions. If verification passes and the request succeeds, the Agora server returns the conversion progress to the app server.

Invalid Token

A token becomes invalid if one of the following happens:

  • The linked project is disabled or deleted. This also disables or deletes the access keys in the project, thus invalidating the tokens generated using those access keys.
  • The token expires. Once a token expires, a user cannot use it to join a room or access Interactive Whiteboard.

Token errors

You might encounter the following token errors when using Interactive Whiteboard:

ErrorInstruction
invalid format of tokenThe data format of the token is wrong. Please check:
  • Whether the data type is string.
  • Whether there are extra spaces or characters before and after the token string.
  • Whether the prefix is correct:
    • An SDK Token is prefixed with NETLESSSDK_
    • A Room Token is prefixed with NETLESSROOM_
    • A Task Token is prefixed with NETLESSTASK_
  • expired tokenThe token expires. Please call the Interactive Whiteboard RESTful API or use code to generate a new token from the app server.
    invalid signature of tokenThe token signature is invalid. This error might occur if you use code to generate a token from the app server. Ensure that your algorithm and code are correct.
    unknown errorAn unknown error occurs.
    token access role$ {permission} forbiddenThe token cannot grant the permission because it is assigned to an inferior role. For instance, you use a reader token to access services that must be granted by a writer token. Ensure that the token you use can grant the permissions you need.
    token access task forbiddenThe Task Token is banned from accessing the file-conversion task. Ensure that the Task Token is generated using the Task UUID of the corresponding file-conversion task.
    token access room forbiddenThe Room Token is banned from accessing the room. Ensure that the Room Token is generated using the Room UUID of the corresponding room.
    token access team forbiddenThe token is invalid because the linked project is deleted or disabled.
    vundefined