The room object represents any form of communication between two or more users.
There are at least two fields on the room object.
_id
: The room/user id (depends on the room type)t
: The room type
The IRoom interface represents the Room object defining the properties and their types that can be associated with a Room. Room information is stored in the rocketchat_room
collection on MongoDB.
See the IRoom interface here.
{% embed url="https://github.com/RocketChat/Rocket.Chat/blob/develop/packages/core-typings/src/IRoom.ts" %}
Example Object
{
"_id": "DMDsF2QKqqQoXsxha",
"fname": "private-channel",
"customFields": {},
"description": "",
"broadcast": false,
"encrypted": false,
"federated": false,
"name": "private-channel",
"t": "p",
"msgs": 6,
"usersCount": 2,
"u": {
"_id": "rYhzFRd2QZjNwAAXX",
"username": "rodriq"
},
"ts": {
"$date": "2023-02-06T13:37:13.763Z"
},
"ro": false,
"default": false,
"sysMes": true,
"_updatedAt": {
"$date": "2023-03-08T21:17:55.262Z"
},
"lastMessage": {
"_id": "5RPPKj9nyHEmbjqt8",
"rid": "DMDsF2QKqqQoXsxha",
"u": {
"_id": "rYhzFRd2QZjNwAAXX",
"username": "rodriq",
"name": "Rodriq"
},
"msg": "Hey, check this file I've just shared: [temp Docs](https://docs.google.com/document/d/1oZG.../edit?usp=drivesdk)",
"ts": {
"$date": "2023-03-08T21:17:54.814Z"
},
"_updatedAt": {
"$date": "2023-03-08T21:17:55.245Z"
},
"groupable": false,
"attachments": [
{
"ts": "1970-01-01T00:00:00.000Z",
"image_url": ""
}
],
"parseUrls": true,
"urls": [
{
"url": "https://docs.google.com/document/d/1oZGW2...Bc/edit?usp=drivesdk"
}
],
"mentions": [],
"channels": [],
"md": [
{
"type": "PARAGRAPH",
"value": [
{
"type": "PLAIN_TEXT",
"value": "Hey, check this file I've just shared: "
},
{
"type": "LINK",
"value": {
"src": {
"type": "PLAIN_TEXT",
"value": "https://docs.google.com/document/d/1oZGW2bd...LBc/edit?usp=drivesdk"
},
"label": [
{
"type": "PLAIN_TEXT",
"value": "temp Microservices Docs"
}
]
}
}
]
}
]
},
"lm": {
"$date": "2023-03-08T21:17:54.814Z"
}
}
The Room object has these fields
Field | Data Type | Description |
---|---|---|
_id | string | Room ID |
t | string | Room type. E.g c = chanel, d = direct message, l = live chat, p=private chat |
name | string | The name of the room |
fname | string | The full name of the room |
msgs | number | The number of messages in the room |
default | true | Indicates if the room is the default room |
broadcast | true | Indicates if the room is a broadcast room |
featured | true | Indicates if the room is featured |
announcement | string | The announcement or summary of the room |
joinCodeRequired | boolean | Indicates if a join code is required to enter the room |
announcementDetails | { style?: string } | Additional details about the room announcement, such as the style |
encrypted | boolean | Indicates if the room is encrypted |
topic | string | The topic of the room |
reactWhenReadOnly | boolean | Indicates if reactions are allowed when the room is read-only |
sysMes | MessageTypesValues[] | boolean | Indicates whether system messages are enabled or an array of allowed system message types |
u | string | Information about the user who created the room(_id: string, username: string, name: string ) |
uids | Array<string> | Array of user IDs in the room |
lastMessage | IMessage | The last message sent in the room |
lm | Date | Timestamp of the last message |
usersCount | number | The number of users in the room |
callStatus | CallStatus | The status of a call in the room |
webRtcCallStartTime | Date | The start time of a WebRTC call in the room |
servedBy | string | Information about the user who served the room{ _id: string } |
streamingOptions | string | Options for streaming content in the room { id?: string, type?: string, url?: string, thumbnail?: string, isAudioOnly?: boolean, message?: string } |
prid | string | The primary room ID (for threads) |
avatarETag | string | The ETag for the room avatar |
teamMain | boolean | Indicates if the room is the main room for a team |
teamId | string | The ID of the team the room belongs to |
teamDefault | boolean | Indicates if the room is the default room for the team |
open | boolean | Indicates if the room is open |
autoTranslateLanguage | string | The language used for automatic translation in the room |
autoTranslate | boolean | Indicates if automatic translation is enabled for the room |
unread | number | The number of unread messages in the room |
alert | boolean | Indicates if there is an alert in the room |
hideUnreadStatus | boolean | Indicates if the unread status is hidden |
hideMentionStatus | boolean | Indicates if the mention status is hidden |
muted | string[] | Array of user IDs who are muted in the room |
unmuted | string[] | Array of user IDs who are not muted in the room |
usernames | string[] | Array of usernames in the room |
ts | Date | Timestamp of when the room was created |
cl | boolean | Indicates if the room is a channel |
ro | boolean | Indicates if the room is read-only |
favorite | boolean | Indicates if the room is marked as a favorite |
archived | boolean | Indicates if the room is archived |
description | string | Description or summary of the room |
createdOTR | boolean | Indicates if the room was created as an OTR (off-the-record) room |
e2eKeyId | string | Key ID for end-to-end encryption in the room |
federated | boolean | (Deprecated) Indicates if the room is federated |
customFields | Object | (Deprecated) Custom fields for additional room information |
channel | { _id: string } | Information about the channel the room belongs to |
d
: Direct chatc
: Chatp
: Private chatl
: Livechat
The information that comes with the room object changes according to its type.
{% tabs %} {% tab title="Direct chat" %} A direct chat between two users. In this case, the room object only has two fields:
_id
: The room idt
: The room type (in this cased
)
Example:
{
"_id": "room-id",
"t": "d"
}
You'll need to access the room information using data from Get Subscriptions. {% endtab %}
{% tab title="Chat" %} An open chatroom. A chat contains more information about the room as it follows:
_id
: The room idt
: The room type (in this casec
)name
: The room nameu
: The room creator (it may return a null user)topic
: (Optional) The room topicmuted
: (Optional) A collection of muted users by its usernamejitsiTimeout
: (Optional) (?)
Example:
{
"_id": "room-id",
"t": "c",
"name": "room-name",
"u": { "_id": "user-id", "username": "username" },
"topic": "room-topic",
"muted": [ "username" ],
"jitsiTimeout": { "$date": 1480377601 }
}
{% endtab %}
{% tab title="Private chat" %} A private chatroom. This type of room resembles the open chat room with an addition.
_id
: The room idt
: The room type (in this casep
)name
: The room nameu
: The room creator (it may return a null user)topic
: (Optional) The room topicmuted
: (Optional) A collection of muted users by its usernamejitsiTimeout
: (Optional) (?)ro
: Flags if the room is read-only
Example:
{
"_id": "room-id",
"t": "p",
"name": "room-name",
"u": { "_id": null, "username": null },
"topic": "room-topic",
"ro": false // This room is not read-only
}
{% endtab %} {% endtabs %}