Links

Room

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.

Room Object

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"
}
}

Fields

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

Room Types

  • d: Direct chat
  • c: Chat
  • p: Private chat
  • l: Livechat
The information that comes with the room object changes according to its type.
Direct chat
Chat
Private chat
A direct chat between two users. In this case, the room object only has two fields:
  • _id: The room id
  • t: The room type (in this case d)
Example:
{
"_id": "room-id",
"t": "d"
}
You'll need to access the room information using data from Get Subscriptions.
An open chatroom. A chat contains more information about the room as it follows:
  • _id: The room id
  • t: The room type (in this case c)
  • name: The room name
  • u: The room creator (it may return a null user)
  • topic: (Optional) The room topic
  • muted: (Optional) A collection of muted users by its username
  • jitsiTimeout: (Optional) (?)
Example:
{
"_id": "room-id",
"t": "c",
"name": "room-name",
"u": { "_id": "user-id", "username": "username" },
"topic": "room-topic",
"muted": [ "username" ],
"jitsiTimeout": { "$date": 1480377601 }
}
A private chatroom. This type of room resembles the open chat room with an addition.
  • _id: The room id
  • t: The room type (in this case p)
  • name: The room name
  • u: The room creator (it may return a null user)
  • topic: (Optional) The room topic
  • muted: (Optional) A collection of muted users by its username
  • jitsiTimeout: (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
}

Last modified 5mo ago
Deprecation for cloud services and apps is now extended to November 20, 2023. Rocket.Chat versions receive support for six months after release.