Skip to contentSkip to navigationSkip to topbar
On this page

REST API: Rooms



Overview

overview page anchor

The Programmable Video Rooms resource represents a communications session among multiple endpoints using one of Twilio's Programmable Video SDKs. Connected users (Participants) can share video and audio Tracks with the Room, and receive video and audio Tracks from other Participants in the Room.

The Rooms resource lets you dynamically create and complete Rooms, and configure a Room's topology and behavior. Use this API to set Room properties such as its name, type, TURN configuration, webhook status callback URL, and the maximum number of Participants.

All Programmable Video REST API resources use the following base URL.

1
https://video.twilio.com
2

Resource URI

resource-uri page anchor
1
/v1/Rooms/{RoomNameOrSid}
2
Property nameTypeRequiredDescriptionChild properties
sidSID<RM>

Optional

Not PII

The unique string that Twilio created to identify the Room resource.

Pattern: ^RM[0-9a-fA-F]{32}$Min length: 34Max length: 34

statusenum<string>

Optional

The status of the room. Can be: in-progress, failed, or completed.

Possible values:
in-progresscompletedfailed

date_updatedstring<date-time>

Optional

The date and time in GMT when the resource was last updated specified in ISO 8601(link takes you to an external page) format.


account_sidSID<AC>

Optional

The SID of the Account that created the Room resource.

Pattern: ^AC[0-9a-fA-F]{32}$Min length: 34Max length: 34

enable_turnboolean

Optional

Deprecated, now always considered to be true.


unique_namestring

Optional

An application-defined string that uniquely identifies the resource. It can be used as a room_sid in place of the resource's sid in the URL to address the resource, assuming it does not contain any reserved characters(link takes you to an external page) that would need to be URL encoded. This value is unique for in-progress rooms. SDK clients can use this name to connect to the room. REST API clients can use this name in place of the Room SID to interact with the room as long as the room is in-progress.


status_callbackstring<uri>

Optional

The URL Twilio calls using the status_callback_method to send status information to your application on every room event. See Status Callbacks for more info.


status_callback_methodenum<http-method>

Optional

The HTTP method Twilio uses to call status_callback. Can be POST or GET and defaults to POST.

Possible values:
GETPOST

end_timestring<date-time>

Optional

The UTC end time of the room in ISO 8601(link takes you to an external page) format.


durationinteger

Optional

The duration of the room in seconds.


typeenum<string>

Optional

This is a legacy parameter. The only available Room type is group. Twilio customers who were using other Room types prior to October 21, 2024 can also use the types go, peer-to-peer, and group-small. Learn more in Legacy Video Room Types.

Possible values:
gopeer-to-peergroupgroup-small

max_participantsinteger

Optional

The maximum number of concurrent Participants allowed in the room.

Default: 0

max_participant_durationinteger

Optional

The maximum number of seconds a Participant can be connected to the room. The maximum possible value is 86400 seconds (24 hours). The default is 14400 seconds (4 hours).

Default: 0

max_concurrent_published_tracksinteger

Optional

The maximum number of published audio, video, and data tracks all participants combined are allowed to publish in the room at the same time. Check Programmable Video Limits for more details. If it is set to 0 it means unconstrained.


record_participants_on_connectboolean

Optional

Whether to start recording when Participants connect.


video_codecsarray[enum<string>]

Optional

An array of the video codecs that are supported when publishing a track in the room. Can be: VP8 and H264.

Possible values:
VP8H264

media_regionstring

Optional

The region for the Room's media server. Can be one of the available Media Regions.


audio_onlyboolean

Optional

When set to true, indicates that the participants in the room will only publish audio. No video tracks will be allowed.


empty_room_timeoutinteger

Optional

Specifies how long (in minutes) a room will remain active after last participant leaves. Can be configured when creating a room via REST API. For Ad-Hoc rooms this value cannot be changed.

Default: 0

unused_room_timeoutinteger

Optional

Specifies how long (in minutes) a room will remain active if no one joins. Can be configured when creating a room via REST API. For Ad-Hoc rooms this value cannot be changed.

Default: 0

large_roomboolean

Optional

Indicates if this is a large room.


urlstring<uri>

Optional

The absolute URL of the resource.


linksobject<uri-map>

Optional

The URLs of related resources.

HTTP GET

get-instance page anchor

Returns a single Room resource represented by {RoomNameOrSid} .

Retrieve an in-progress Room instance by UniqueName

get-by-unique-name page anchor

You can retrieve an in-progress Room instance object using the Room's UniqueName, assuming the UniqueName does not contain any reserved characters(link takes you to an external page) that would need to be URL encoded. This makes it easier to interact with Twilio's REST API without having to keep track of Twilio's Room SID identifiers.

For example:

GET /Rooms/DailyStandup
Retrieve an in-progress Room instance by UniqueNameLink to code sample: Retrieve an in-progress Room instance by UniqueName
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function fetchRoom() {
11
const room = await client.video.v1.rooms("DailyStandup").fetch();
12
13
console.log(room.sid);
14
}
15
16
fetchRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "DailyStandup",
8
"enable_turn": true,
9
"unique_name": "unique_name",
10
"max_participants": 10,
11
"max_participant_duration": 86400,
12
"max_concurrent_published_tracks": 0,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": null,
16
"record_participants_on_connect": false,
17
"video_codecs": [
18
"VP8"
19
],
20
"audio_only": false,
21
"media_region": "us1",
22
"empty_room_timeout": 5,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Will return the Room instance object for the Room DailyStandup if the room is currently in-progress. If no Room exists by the name DailyStandup, or a Room by that name is only in completed status, the above request will return an HTTP 404 response.

Retrieve an in-progress or completed Room instance by RoomSid

get-by-sid page anchor

A Room's SID property is Twilio's own canonical unique identifier for a Room. You can always use the Room SID to retrieve the Room, whether the room is in-progress or completed.

For example:

GET /Rooms/RMxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Retrieve an in-progress or completed Room instance by RoomSidLink to code sample: Retrieve an in-progress or completed Room instance by RoomSid
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function fetchRoom() {
11
const room = await client.video.v1
12
.rooms("RMXXXXXXXXXXXXXXXXXXXXXXXXXXXXX")
13
.fetch();
14
15
console.log(room.sid);
16
}
17
18
fetchRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "RMXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
8
"enable_turn": true,
9
"unique_name": "unique_name",
10
"max_participants": 10,
11
"max_participant_duration": 86400,
12
"max_concurrent_published_tracks": 0,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": null,
16
"record_participants_on_connect": false,
17
"video_codecs": [
18
"VP8"
19
],
20
"audio_only": false,
21
"media_region": "us1",
22
"empty_room_timeout": 5,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Will return the Room instance object for the Room with SID RMxxxxxxxxxxxxxxxxxxxxxxxxxxxxx, regardless of its status. If no Room exists with that SID, the above request will return an HTTP 404 response.

Modifies a Room resource.

Supported POST parameters

Property nameTypeRequiredPIIDescription
Sidstringrequired

The SID of the Room resource to update.

Encoding type:application/x-www-form-urlencoded
SchemaExample
Property nameTypeRequiredDescriptionChild properties
Statusenum<string>required

The new status of the resource. Set to completed to end the room.

Possible values:
in-progresscompletedfailed

Update a Room's status to completed with the following request to end the Room. All connected Participants will be immediately disconnected from the Room.

1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function updateRoom() {
11
const room = await client.video.v1
12
.rooms("RMXXXXXXXXXXXXXXXXXXXXXXXXXXXXX")
13
.update({ status: "completed" });
14
15
console.log(room.sid);
16
}
17
18
updateRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "completed",
6
"type": "peer-to-peer",
7
"sid": "RMXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
8
"enable_turn": true,
9
"unique_name": "unique_name",
10
"max_participants": 10,
11
"max_participant_duration": 86400,
12
"max_concurrent_published_tracks": 10,
13
"status_callback_method": "POST",
14
"status_callback": null,
15
"record_participants_on_connect": false,
16
"video_codecs": [
17
"VP8"
18
],
19
"media_region": "us1",
20
"audio_only": false,
21
"empty_room_timeout": 5,
22
"unused_room_timeout": 5,
23
"end_time": "2015-07-30T20:00:00Z",
24
"large_room": false,
25
"duration": 10,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

1
/v1/Rooms
2

Create a new Room with an HTTP POST to the Rooms list resource.

Once you create a Room, you will need to generate Access Tokens and use Twilio's client-side Video SDKs to connect to the Room. Learn more about the full video application lifecycle in the Video Overview page. Below are the Getting Started guides for each client-side SDK, which explain how to connect to and interact with Rooms:

  • JavaScript
  • iOS
  • Android

Supported POST parameters

post-parameters page anchor
Encoding type:application/x-www-form-urlencoded
SchemaExample
Property nameTypeRequiredDescriptionChild properties
EnableTurnboolean

Optional

Deprecated, now always considered to be true.


Typeenum<string>

Optional

This is a legacy parameter that does not need to be set. The only available Room type is group. Twilio customers who were using other Room types prior to October 21, 2024 can also use the types go, peer-to-peer, and group-small. Learn more in Legacy Video Room Types.

Possible values:
gopeer-to-peergroupgroup-small

UniqueNamestring

Optional

An application-defined string that uniquely identifies the resource. It can be used as a room_sid in place of the resource's sid in the URL to address the resource, assuming it does not contain any reserved characters(link takes you to an external page) that would need to be URL encoded. This value is unique for in-progress rooms. SDK clients can use this name to connect to the room. REST API clients can use this name in place of the Room SID to interact with the room as long as the room is in-progress.


StatusCallbackstring<uri>

Optional

The URL Twilio should call using the status_callback_method to send status information to your application on every room event. See Status Callbacks for more info.


StatusCallbackMethodenum<http-method>

Optional

The HTTP method Twilio should use to call status_callback. Can be POST or GET.

Possible values:
GETPOST

MaxParticipantsinteger

Optional

The maximum number of concurrent Participants allowed in the room. The maximum allowed value is 50.


RecordParticipantsOnConnectboolean

Optional

Whether to start recording when Participants connect.


VideoCodecsarray[enum<string>]

Optional

An array of the video codecs that are supported when publishing a track in the room. Can be: VP8 and H264.

Possible values:
VP8H264

MediaRegionstring

Optional

The region for the Room's media server. Can be one of the available Media Regions.


RecordingRulesobject

Optional

A collection of Recording Rules that describe how to include or exclude matching tracks for recording


AudioOnlyboolean

Optional

When set to true, indicates that the participants in the room will only publish audio. No video tracks will be allowed.


MaxParticipantDurationinteger

Optional

The maximum number of seconds a Participant can be connected to the room. The maximum possible value is 86400 seconds (24 hours). The default is 14400 seconds (4 hours).


EmptyRoomTimeoutinteger

Optional

Configures how long (in minutes) a room will remain active after last participant leaves. Valid values range from 1 to 60 minutes (no fractions).


UnusedRoomTimeoutinteger

Optional

Configures how long (in minutes) a room will remain active if no one joins. Valid values range from 1 to 60 minutes (no fractions).


LargeRoomboolean

Optional

When set to true, indicated that this is the large room.

(information)

Info

Rooms created via the REST API exist for five minutes to allow the first Participant to connect. If no Participants join within five minutes, the Room times out and a new Room must be created.

Example 1: Create a Room called "DailyStandup"

create-room page anchor
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function createRoom() {
11
const room = await client.video.v1.rooms.create({
12
uniqueName: "DailyStandup",
13
});
14
15
console.log(room.sid);
16
}
17
18
createRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
8
"enable_turn": true,
9
"unique_name": "DailyStandup",
10
"max_concurrent_published_tracks": 0,
11
"max_participants": 10,
12
"max_participant_duration": 86400,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": null,
16
"record_participants_on_connect": false,
17
"video_codecs": [
18
"VP8"
19
],
20
"media_region": "us1",
21
"audio_only": false,
22
"empty_room_timeout": 5,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Example 2: Create a Room, enable Recording, and set a Status Callback URL

example-2-create-a-room-enable-recording-and-set-a-status-callback-url page anchor
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function createRoom() {
11
const room = await client.video.v1.rooms.create({
12
recordParticipantsOnConnect: true,
13
statusCallback: "http://example.org",
14
uniqueName: "DailyStandup",
15
});
16
17
console.log(room.sid);
18
}
19
20
createRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
8
"enable_turn": true,
9
"unique_name": "DailyStandup",
10
"max_concurrent_published_tracks": 0,
11
"max_participants": 10,
12
"max_participant_duration": 86400,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": "http://example.org",
16
"record_participants_on_connect": true,
17
"video_codecs": [
18
"VP8"
19
],
20
"media_region": "us1",
21
"audio_only": false,
22
"empty_room_timeout": 5,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Example 3: Create a Room with a 60 minute empty room timeout

example-3-create-a-room-with-a-60-minute-empty-room-timeout page anchor

By default, a Room will end five minutes after the last participant disconnects from the Room. You can configure this to be a different value up to 60 minutes when you create the Room via the REST API. The value is specified in minutes.

The example below demonstrates configuring the Room's empty room timeout value. Note that you can also configure with the Room's unused room timeout value in the same way. The unused room timeout determines how long to wait before ending the Room if no participants join.

Create a Room with a 60 Minute Empty Room TimeoutLink to code sample: Create a Room with a 60 Minute Empty Room Timeout
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function createRoom() {
11
const room = await client.video.v1.rooms.create({
12
emptyRoomTimeout: 60,
13
uniqueName: "DailyStandup",
14
});
15
16
console.log(room.sid);
17
}
18
19
createRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
8
"enable_turn": true,
9
"unique_name": "DailyStandup",
10
"max_concurrent_published_tracks": 0,
11
"max_participants": 10,
12
"max_participant_duration": 86400,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": null,
16
"record_participants_on_connect": false,
17
"video_codecs": [
18
"VP8"
19
],
20
"media_region": "us1",
21
"audio_only": false,
22
"empty_room_timeout": 60,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Returns a list of Room resources created in the given account. The list includes paging information.

The following GET query string parameters allow you to limit the list returned. Note, parameters are case-sensitive.

Property nameTypeRequiredPIIDescription
Statusenum<string>

Optional

Read only the rooms with this status. Can be: in-progress (default) or completed

Possible values:
in-progresscompletedfailed

UniqueNamestring

Optional

Read only rooms with the this unique_name.


DateCreatedAfterstring<date-time>

Optional

Read only rooms that started on or after this date, given as YYYY-MM-DD.


DateCreatedBeforestring<date-time>

Optional

Read only rooms that started before this date, given as YYYY-MM-DD.


PageSizeinteger

Optional

How many resources to return in each list page. The default is 50, and the maximum is 1000.

Minimum: 1Maximum: 1000

Pageinteger

Optional

The page index. This value is simply for client state.

Minimum: 0

PageTokenstring

Optional

The page token. This is provided by the API.

Filter Rooms by UniqueName

filter-by-unique-name page anchor
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function listRoom() {
11
const rooms = await client.video.v1.rooms.list({
12
status: "completed",
13
uniqueName: "DailyStandup",
14
limit: 20,
15
});
16
17
rooms.forEach((r) => console.log(r.sid));
18
}
19
20
listRoom();

Output

1
{
2
"rooms": [],
3
"meta": {
4
"page": 0,
5
"page_size": 50,
6
"first_page_url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
7
"previous_page_url": null,
8
"url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
9
"next_page_url": null,
10
"key": "rooms"
11
}
12
}

Returns a list containing any completed Rooms with the name DailyStandup. Note that the status parameter defaults to in-progress. If no status is provided, this endpoint will return a list containing only in-progress rooms with the name DailyStandup.

Filter Rooms by Status

filter-by-status page anchor
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function listRoom() {
11
const rooms = await client.video.v1.rooms.list({
12
status: "completed",
13
limit: 20,
14
});
15
16
rooms.forEach((r) => console.log(r.sid));
17
}
18
19
listRoom();

Output

1
{
2
"rooms": [],
3
"meta": {
4
"page": 0,
5
"page_size": 50,
6
"first_page_url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
7
"previous_page_url": null,
8
"url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
9
"next_page_url": null,
10
"key": "rooms"
11
}
12
}

Using multiple list filters

multiple-list-filters page anchor
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function listRoom() {
11
const rooms = await client.video.v1.rooms.list({
12
status: "completed",
13
uniqueName: "DailyStandup",
14
limit: 20,
15
});
16
17
rooms.forEach((r) => console.log(r.sid));
18
}
19
20
listRoom();

Output

1
{
2
"rooms": [],
3
"meta": {
4
"page": 0,
5
"page_size": 50,
6
"first_page_url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
7
"previous_page_url": null,
8
"url": "https://video.twilio.com/v1/Rooms?PageSize=50&Page=0",
9
"next_page_url": null,
10
"key": "rooms"
11
}
12
}
Configure the maximum Participant durationLink to code sample: Configure the maximum Participant duration
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function createRoom() {
11
const room = await client.video.v1.rooms.create({
12
maxParticipantDuration: 86400,
13
uniqueName: "DailyStandup",
14
});
15
16
console.log(room.sid);
17
}
18
19
createRoom();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"date_created": "2015-07-30T20:00:00Z",
4
"date_updated": "2015-07-30T20:00:00Z",
5
"status": "in-progress",
6
"type": "peer-to-peer",
7
"sid": "RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
8
"enable_turn": true,
9
"unique_name": "DailyStandup",
10
"max_concurrent_published_tracks": 0,
11
"max_participants": 10,
12
"max_participant_duration": 86400,
13
"duration": 0,
14
"status_callback_method": "POST",
15
"status_callback": null,
16
"record_participants_on_connect": false,
17
"video_codecs": [
18
"VP8"
19
],
20
"media_region": "us1",
21
"audio_only": false,
22
"empty_room_timeout": 5,
23
"unused_room_timeout": 5,
24
"end_time": "2015-07-30T20:00:00Z",
25
"large_room": false,
26
"url": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
27
"links": {
28
"participants": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Participants",
29
"recordings": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Recordings",
30
"recording_rules": "https://video.twilio.com/v1/Rooms/RMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/RecordingRules"
31
}
32
}

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.