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

The room ID.

t

String

The room type. E.g c = channel, d = direct message, l = livechat, p=private chat

name

String

The room’s name.

fname

String

The full name of the room.

msgs

Number

The number of messages in the room.

default

Boolean

Indicates if the room is the default room.

broadcast

Boolean

Indicates if the room is a broadcast room.

featured

Boolean

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

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 of string

Array of user IDs in the room.

lastMessage

Object

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

Array of string

An array of user IDs who are muted in the room.

unmuted

Array of string

An array of user IDs who are not muted in the room.

usernames

Array of string

An 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 messages

  • c: Public channel

  • p: Private channel

  • discussions: Team or channel discussions

  • teams: Workspace teams

  • l: Livechat

  • v: Omnichannel VoIP rooms

The information that comes with the room object changes according to its type.

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

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
}