Skip to content

Latest commit

 

History

History
252 lines (220 loc) · 37.8 KB

File metadata and controls

252 lines (220 loc) · 37.8 KB

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.

{% embed url="https://github.com/RocketChat/Rocket.Chat/blob/develop/packages/core-typings/src/IRoom.ts" %}

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.

{% tabs %} {% tab title="Direct 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. {% endtab %}

{% tab title="Chat" %} 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 }
}

{% endtab %}

{% tab title="Private chat" %} 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
}

{% endtab %} {% endtabs %}