Presence
The presence feature of a chat room enables online users to advertise to others that they are online. Use this feature to build online status indicators to display who is online in a chat room. Users can also share additional information such as avatar URLs or custom statuses.
Subscribe to presence
Subscribe to users' presence status by registering a listener. Presence events are emitted whenever a member enters or leaves the presence set, or updates their user data. Use the presence.subscribe() method in a room to receive updates:
1
2
3
const { unsubscribe } = room.presence.subscribe((event) => {
  console.log(`${event.member.clientId} entered with data: ${event.member.data}`);
});Presence event structure
The following are the properties of a presence event:
| Property | Description | Type | 
|---|---|---|
| type | The type of the event | String | 
| member | The presence member that the event pertains to | PresenceMember | 
| clientId: The ID of the client that triggered the event. | String | |
| connectionId: The connection ID of the client that triggered the event. Use this in combination withclientIdto identify a user across multiple devices. | String | |
| data: Optional user data. | Object | |
| updatedAt: The time that the event was emitted. | DateTime | |
| extras: A JSON object of arbitrary key-value pairs that may contain metadata, and/or ancillary payloads related to the user's latest presence event. | JSONObject(optional) | 
Unsubscribe from presence
Use the unsubscribe() function returned in the subscribe() response to remove a presence listener:
1
2
3
4
5
6
7
// Initial subscription
const { unsubscribe } = room.presence.subscribe((event) => {
  console.log(`${event.member.clientId} entered with data: ${event.member.data}`);
});
// To remove the listener
unsubscribe();Set user presence
Users can enter and leave the presence set of a room to indicate when they are online or offline. They can also set user data when entering and leaving the set, such as their current status. Presence is also linked to a user's connection status. For example, if a user goes offline then a leave event will be emitted for them.
Use the presence.enter() method to indicate when a user joins a room. This will send a presence event to all users subscribed to presence indicating that a new member has joined the chat. You can also set an optional data field with information such as the status of a user:
1
await room.presence.enter({ status: 'available' });Use the presence.update() method when a user wants to update their data, such as an update to their status, or to indicate that they're raising their hand. Updates will send a presence event to all users subscribed to presence:
1
await room.presence.update({ status: 'busy' });Use the presence.leave() method to explicitly remove a user from the presence set. This will send a presence event to all users subscribed to presence. You can also set an optional data field such as setting a status of 'Back later'.
1
await room.presence.leave({ status: 'Be back later!' });When a user goes offline or closes their connection, a leave event is also emitted and they are removed from the presence set.
Presence options
The following options can be set when creating a room that are specific to presence:
| Property | Description | Default | 
|---|---|---|
| enableEvents | Set whether the client has permissions to subscribe to the presence set. Calling presence.subscribe()is still required. | true | 
Retrieve the presence set
The online presence of users can be retrieved in one-off calls. This can be used to check the status of an individual user, or return the entire presence set as an array.
Use the presence.get() method to retrieve an array of all users currently entered into the presence set, or individual users:
1
2
3
4
5
// Retrieve all users entered into presence as an array:
const presentMembers = await room.presence.get();
// Retrieve the status of specific users by their clientId:
const presentMember = await room.presence.get({ clientId: 'clemons123' });Alternatively, use the presence.isUserPresent() method and pass in a user's clientId to check whether they are online or not. This will return a boolean:
1
const isPresent = await room.presence.isUserPresent('clemons123');Presence member structure
The following are the properties of an individual presence member:
| Property | Description | Type | 
|---|---|---|
| clientId | The ID of the client this event relates to. | String | 
| data | The latest optional user data associated with the user. | Object | 
| extras | A JSON object of arbitrary key-value pairs that may contain metadata, and/or ancillary payloads related to the user's latest presence event. | JsonObject (optional) | 
| updatedAt | The time of the last presence event. | DateTime |