Supergroup channel
A Supergroup channel is an expanded version of a group channel, which can accommodate a massive number of members while serving the same functions as a group channel. The maximum number can stretch up to tens of thousands of members depending on your Sendbird plan. Because a Supergroup channel is built upon the same foundation as a group channel, Platform APIs and SDK functions for both channel types are identical.
Note: Supergroup and group channels are alike in terms of Platform API and SDK design, except for the
super
option. Thesuper
option indicates whether the channel is a Supergroup channel or a group channel.
Use cases
Supergroup channels can be used for a wide range of occasions that demand real-time engagement among a large number of users. One of the common use cases for Supergroup channels is community building, ranging from public forums to private events with a large number membership.
- Ask-me-anything events: Supergroup channels also work as a platform for users to seek advice from an influencer or expert.
- Gaming community: Another common set-up is gaming communities, where users gather to find players to team up with or exchange ideas and strategies to advance further in the game.
- Stand-ups: Supergroup channels are a great place for midsize conferences, such as a organization-wide stand-up.
Note: To learn about differences among open channels, group channels, and Supergroup channels, see Channel types.
Limitations
To secure stable operation and optimized user experience of a Supergroup channel, a few functions are subject to limits. Some of those limitations include:
- Visual interactions: read and delivery receipts aren’t supported in Supergroup channels to provide an optimal performance in Supergroup channels.
- Unread counts: unread counts are marked up to 100 only. In the case they surpass 100, we suggest you display the counts as
99+
to avoid confusion. - Push notifications: The way push notifications for Supergroup channels work is determined by two factors: the number of members in a channel and the online status of its member.
- When there are less than 100 members: A push notification will be sent for every message created in the channel.
- When there are 100 members or more: A ten-minute time window will be applied to Supergroup channels with more than 100 members. Once the number of members exceeds 100 and a new message is created, a push notification will be sent for the new message and then the next push notification can come ten minutes after that.
For example, the number of members in Channel A surpasses 100 at 13:00 and then a new message is sent at 13:01, a push notification will be sent for the 13:01 message and the ten-minute time window begins. For the following ten minutes, there will be no push notifications for any messages created within the time frame. When ten minutes pass and another message is sent at 13:11, the second push notification will be made for that message. - When a user becomes active: If one of the Supergroup channel members enters the channel and reads a message, the user will be recognized as active. Then only for the following one minute, the user will be receiving push notifications for all messages sent within the time frame.
Open channel vs. Group channel vs. Supergroup channel
The following table compares the difference among three types of channels that can accommodate a large number of users: Open channels, Group channels, and Supergroup channels.
Open channel | Group channel | Supergroup channel | |
---|---|---|---|
Maximum number in a channel | Up to millions of participants | 100 members | Up to tens of thousands of members depending on your Sendbird plan. |
Accessible by | Anyone within the application | Invited users only if private or anyone if public | Invited users only if private or anyone if public |
Ephemeral messaging | Supported | ||
Online presence | |||
Last message | N/A | ||
Supported | Supported | Supported | |
Ban users | |||
Mute users | |||
Freeze channels | |||
N/A | N/A | ||
Read receipts | N/A | N/A | |
Unread counts | N/A | Supported | |
Typing indicators | N/A | Supported | |
Mention others in message | |||
Mention counts | N/A | Supported | Supported |
Reactions | N/A | ||
Spam flood protection | |||
Supported | Supported | Supported | |
Smart throttling | Supported (Default: true) | Supported (Default: false) | Supported (Default: false) |
Push notifications | N/A | Supported | Supported |
Get a channel with its member list | N/A | Supported | Supported |
Pagination for participant list or member list | |||
Order of channel list | - Chronological | - Chronological | - Chronological |
Create a Supergroup channel
Creating a Supergroup channel follows exactly the same process of creating a group channel with one exception of the setSuper()
method. The GroupChannelParams
class has the setSuper()
method, which determines whether a newly created channel will be a Supergroup channel or a group channel. By setting it to true, a new Supergroup channel is created.
Note: Supergroup channels are not supported with the
distinct
option and the option is false by default.
Retrieve a list of Supergroup channels using a filter
Like how you search group channels using filters, you can retrieve a list of Supergroup channels through the GroupChannelListQuery
's setSuperChannelFilter()
method. You can tell which channel is a Supergroup channel by looking for the groupChannel.isSuper
property. If the property has a value of true, the channel is a Supergroup channel.