Screenshots
The screenshot-management feature is implemented by Interactive Whiteboard. You can take screenshots for a single scene or a scene directory, generate images in PNG format, and upload them to a third-party cloud storage space.
Before calling the RESTful API for screen management, ensure that:
- You have created a third-party cloud storage account and a storage space under that account. Agora supports only Amazon Simple Storage Service (Amazon S3) now.
- You have enabled the screenshot feature and configured storage settings in Agora Console. See Enable whitebaord server-side features.
Screenshot a scene (POST)
Call this API to take screenshots for a single scene.
Prototype
- Method:
POST - Access point:
https://api.netless.link/v5/rooms/{uuid}/screenshots
Request header
Pass in the following parameters in the request header:
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
token | string | Required | An SDK token or room token with the writer or admin role. To get an SDK token, you can: |
region | string | Required | Specifies a data center to process the request: us-sv: Silicon Valley, US, which provides services to North America and South America.sg: Singapore, which provides services to Singapore, East Asia, and Southeast Asia.in-mum: Mumbai, India, which provides services to India.eu: Frankfurt, Europe, which provides services to Europe.cn-hz: Hangzhou, China, which provides services to the areas not covered by other data centers. |
Request path
The following parameters are required in the URL:
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
uuid | string | Required | The room UUID, which is the unique identifier of a room. You can get it by calling the RESTful API to create a room or calling the RESTful API to get room information. |
Request body
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
width | number | Required | The width of the screenshot in pixels. |
height | number | Required | The height of the screenshot in pixels. |
path | string | Optional | The path to the scene, which starts with /. If you do not set this parameter, the default path /init is used. |
Request example
HTTP response
For details about all possible response status codes, see the status code table.
If the status code is 201, the request is successful. The response returns the status code and corresponding parameters.
The following is a response example for a successful request:
Description of parameters in the response:
| Parameter | Data type | Description |
|---|---|---|
url | string | The URL of the screenshot. |
key | string | The filename of the screenshot in the storage space. |
bucket | string | The name of the storage space where the screenshot is saved. |
region | string | The region where the storage space is located. |
If the status code is not 201, the request fails. The response body includes a message field that describes the reason for the failure.
Screenshot a scene directory (POST)
Call this API to take screenshots for a scene directory.
Prototype
- Method:
POST - Access point:
https://api.netless.link/v5/rooms/{uuid}/screenshot-list
Request header
Pass in the following parameters in the request header:
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
token | string | Required | An SDK token or room token with the writer or admin role. To get an SDK token, you can: |
region | string | Required | Specifies a data center to process the request: us-sv: Silicon Valley, US, which provides services to North America and South America.sg: Singapore, which provides services to Singapore, East Asia, and Southeast Asia.in-mum: Mumbai, India, which provides services to India.eu: Frankfurt, Europe, which provides services to Europe.cn-hz: Hangzhou, China, which provides services to the areas not covered by other data centers. |
Request path
The following parameters are required in the URL:
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
uuid | string | Required | The room UUID, which is the unique identifier of a room. You can get it by calling the RESTful API to create a room or calling the RESTful API to get room information. |
Request body
| Parameter | Data type | Required/Optional | Description |
|---|---|---|---|
width | number | Required | The width of the screenshot in pixels. |
height | number | Required | The height of the screenshot in pixels. |
path | string | Required | The path to the scene directory, which starts with /. If you do not set this parameter , the current scene directory is used. |
Request example
HTTP response
For details about all possible response status codes, see the status code table.
If the status code is 201, the request is successful. The response returns the status code and corresponding parameters.
The following is a response example for a successful request:
The response body is an array of the screenshot information for each scene. Every member in the array contains the following parameters:
| Parameter | Data type | Description |
|---|---|---|
url | string | The URL of the screenshot. |
key | string | The filename of the screenshot in the storage space. |
bucket | string | The name of the storage space where the screenshot is saved. |
region | string | The region where the storage space is located. |
If the status code is not 201, the request fails. The response body includes a message field that describes the reason for the failure.