On this page

Create channels

Channel naming

Before creating channels, take the time to carefully plan your naming strategy. Stick to consistent naming conventions and structure your channels thoughtfully. This preparation helps you avoid increased complexity, performance bottlenecks, and scalability issues, ensuring your app remains manageable and efficient as it grows.

Create channels (Channel objects) of one of these types:

Requires App Context

To store data about channels, you must enable App Context for your app's keyset in the Admin Portal.

No support for channel groups

Chat SDKs don't support channel groups. We recommend using a Core SDK to manage channel groups.

Create direct channel

Direct channels enable private conversations between two users, letting one person initiate the chat and send an invitation to another person for:

  • Personal conversations - you can engage in private conversations with friends, family, or colleagues, sharing personal updates, discussing sensitive matters, or planning social events.

  • Professional collaboration - you can use 1:1 chat to have focused discussions, exchange confidential information, provide feedback, or coordinate tasks with colleagues and business partners.

createDirectConversation() is a method that:

  1. Creates a direct (one-on-one) channel type.
  2. Sets channel membership for the channel owner (so that they can join the channel).
  3. Invites the other user to join the channel. As a result, an event of the invite type gets created. You can listen to these events in your chat app and notify the invited users.

If you call this method to create a channel for users that already had a conversation which was not deleted, this conversation is retrieved.

Receive messages

Note that you still have to call the connect() method to subscribe to message event listeners and start receiving messages on the channel.

Method signature

icon

Under the hood


This method takes the following parameters:

1chat.createDirectConversation({ user, channelData, membershipData, }: {
2 user: User,
3 channelId?: string
4 channelData?: {
5 name?: string,
6 description?: string,
7 custom?: ObjectCustom
8 },
9 membershipData?: {
10 custom: ObjectCustom
11 }
12}): Promise<{
13 channel: Channel,
14 hostMembership: Membership,
15 inviteeMembership: Membership,
show all 16 lines

Input

* required
ParameterDescription
user *
Type: User
Default:
n/a
User that you invite to join a channel.
channelId
Type: string
Default:
Automatically generated ID
ID of the direct channel. The channel ID is created automatically by a hashing function that takes the string of two user names joined by &, computes a numeric value based on the characters in that string, and adds the direct prefix in front. For example, direct.1234567890. You can override this default value by providing your own ID.
channelData
Type: object
Default:
n/a
Information about the channel.
 → name
Type: string
Default:
n/a
Display name for the channel.

If you don't provide the name, the channel will get the same name as id (value of channelId).
 → description
Type: string
Default:
n/a
Additional details about the channel.
 → custom
Type: any
Default:
n/a
Any custom properties or metadata associated with the channel.
membershipData
Type: object
Default:
n/a
Information about the user-channel membership.
 → custom *
Default:
n/a
Any custom properties or metadata associated with the channel membership in the form of a JSON. Values must be scalar only; arrays or objects are not supported. App Context filtering language doesn’t support filtering by custom properties.
API limits

To learn about the maximum length of parameters used to set channel metadata, refer to REST API docs.

Output

ParameterDescription
Promise<>
Type: object
Returned object containing these fields: channel, hostMembership, and inviteeMembership.
 → channel
Type: Channel
Returned object containing the updated channel metadata.
 → hostMembershipReturned object containing the updated host (channel owner) metadata.
 → inviteeMembership
Type: Membership
Returned object containing the updated data of the invited user.

Sample code

Invite agent-007 to a 1:1 conversation to talk about customer XYZ.

1// reference the person you want to talk to
2const userToChatWith = await chat.getUser("agent-007")
3
4// add the channel name and topic
5const { channel, hostMembership, inviteeMembership } = await chat.createDirectConversation(
6 {
7 user: userToChatWith,
8 channelData: {
9 name: "Quick sync on customer XYZ"
10 },
11 membershipData: {
12 custom: {
13 purpose: "premium-support"
14 }
15 }
show all 17 lines

Create group channel

Group channels enable communication among multiple users, promoting collaboration and teamwork. A user can initiate a group chat and invite others to be channel members for:

  • Team collaboration - members of a project team can use group chat to share updates, exchange ideas, ask questions, and provide status updates. This boosts real-time collaboration and productivity and ensures everyone stays on the same page.

  • Community building - group chat allows like-minded individuals to connect, discuss shared interests, organize events, and build strong communities around specific topics, hobbies, or professional fields.

Such a chat type is restricted by invitation, and you can access it only when invited.

createGroupConversation() is a method that:

  1. Creates a group channel type.
  2. Sets channel membership for the channel owner (so that they can join the channel).
  3. Invites other users to join the channel.
Receive messages

Note that you still have to call the connect() method to subscribe to message event listeners and start receiving messages on the channel.

Method signature

icon

Under the hood


This method takes the following parameters:

1chat.createGroupConversation({ users, channelId, channelData, membershipData, }: {
2 users: User[],
3 channelId?: string
4 channelData?: {
5 name?: string,
6 description?: string,
7 custom?: ObjectCustom
8 },
9 membershipData?: {
10 custom: ObjectCustom
11 }
12}): Promise<{
13 channel: Channel,
14 hostMembership: Membership,
15 inviteesMemberships: Membership[],
show all 16 lines

Input

* required
ParameterDescription
users *
Type: User[]
Default:
n/a
List of users that you invite to join a channel. You can invite a maximum number of 100 users at once as this is the limitation set by the App Context API that the inviteMultiple() method calls.
channelId
Type: string
Default:
Automatically generated UUIDv4
ID of the group channel. The channel ID is created automatically using the UUIDv4 module. You can override it by providing your own ID.
channelData
Type: object
Default:
n/a
Information about the channel.
 → name
Type: string
Default:
n/a
Display name for the channel.

If you don't provide the name, the channel will get the same name as id (value of channelId).
 → description
Type: string
Default:
n/a
Additional details about the channel.
 → custom
Type: any
Default:
n/a
Any custom properties or metadata associated with the channel.
membershipData
Type: object
Default:
n/a
Information about the user-channel memberships.
 → custom *
Default:
n/a
Any custom properties or metadata associated with the channel membership in the form of a JSON. Values must be scalar only; arrays or objects are not supported. App Context filtering language doesn’t support filtering by custom properties.
API limits

To learn about the maximum length of parameters used to set channel metadata, refer to REST API docs.

Output

ParameterDescription
Promise<>
Type: object
Returned object containing these fields: channel, hostMembership, and inviteeMembership.
 → channel
Type: Channel
Returned object containing the updated channel metadata.
 → hostMembership
Type: Membership
Returned object containing the updated host (channel owner) data.
 → inviteesMemberships
Type: Membership[]
Returned object containing the updated metadata of the invited users.

Sample code

Create a group conversation and invite agent-007 and agent-008 to have weekly syncs on customer XYZ.

1// reference both agents you want to talk to
2const user1 = await chat.getUser("agent-007")
3const user2 = await chat.getUser("agent-008")
4
5// add the channel ID, name, and topic
6const { channel, hostMembership, inviteeMembership } = await chat.createGroupConversation(
7 {
8 users:
9 [
10 user1,
11 user2
12 ],
13 channelId: "group-chat-1"
14 channelData: {
15 name: "Weekly syncs on customer XYZ"
show all 23 lines

Create public channel

Supported features

The public channel type comes with certain limitations in place - you'll get errors when trying to implement such Chat SDK features as typing indicator or read receipts in public channels since these features are neither useful nor practical for large audiences.

Public channels let users engage in open conversations with many people. Unlike group chats, anyone can join public channels. Example use cases include:

  • Knowledge sharing and Q&A - public chats provide a platform for users to seek advice, share knowledge, and participate in discussions related to specific topics, fostering a community-driven environment.

  • Events and webinars - organizations can host public chats during live events, webinars, or panel discussions, allowing attendees to interact with presenters, ask questions, and share insights in real time.

createPublicConversation() is a method that creates such a public channel type with specified metadata.

Receive messages

Note that you still have to call the connect() method to subscribe to message event listeners and start receiving messages on the channel.

Method signature

icon

Under the hood


This method takes the following parameters:

1chat.createPublicConversation({ channelId, channelData, }: {
2 channelId?: string
3 channelData?: {
4 name?: string,
5 description?: string,
6 custom?: ObjectCustom
7 }
8}): Promise<Channel>

Input

* required
ParameterDescription
channelId
Type: string
Default:
Automatically generated UUIDv4
ID of the public channel. The channel ID is created automatically using the UUIDv4 module. You can override it by providing your own ID.
channelData
Type: object
Default:
n/a
Information about the channel.
 → name
Type: string
Default:
n/a
Display name for the channel.

If you don't provide the name, the channel will get the same name as id (value of channelId).
 → description
Type: string
Default:
n/a
Additional details about the channel.
 → custom
Type: any
Default:
n/a
Any custom properties or metadata associated with the channel.
API limits

To learn about the maximum length of parameters used to set channel metadata, refer to REST API docs.

Output

TypeDescription
Promise<Channel>
Object returning the created channel metadata.

Sample code

Create a public ask-support channel.

1const = await chat.createPublicConversation(
2 {
3 channelId: "support-channel-4"
4 channelData: {
5 name: "ask-support"
6 description: "Space dedicated to answering all support-related questions"
7 }
8 }
9)
Last updated on