Skip to main content

Group business overview

Group chat is a common feature in instant messaging apps, allowing two or more users to communicate. RC’s group chat service offers robust group member management, mute controls, offline message push, and historical message roaming. It’s ideal for interest groups, work teams, and customer service communication.

Key features of group chat:

  • The IM service delivers messages to all group members but doesn’t maintain member profiles (avatars, names, etc.) by default.
  • Without RC’s hosting service, group management tasks like creating, disbanding, joining, or leaving a group must be handled by the App server via the IM server API. The client SDK doesn’t provide these methods. For details, see Group management functions.
  • RC’s hosting service offers advanced group management, accessible via both server API and client SDK.
  • There’s no limit to the number of groups under an App Key, with up to 3000 members per group.
  • A single user can join an unlimited number of groups.
  • Enable the cloud storage for one-to-one and group messages service from the Chat pricing plans page in the console to use RC’s message storage for historical message roaming. Available for IM Premium Plan or IM Ultimate Plan. For details, see the billing documentation.

Service configuration

Basic and premium group chat features can be enabled and configured in the [Basic free features] and Chat pricing plans pages in the console.

Client SDK usage notes

tip
  • Global IM UIKit provides ready-to-use group chat UI components. IMLib doesn’t include these components. Global IM UIKit depends on IMLib, so it inherits all IMLib capabilities.
  • Groups created via the hosting service support group management through the client SDK, starting from SDK version 5.12.0.
  • For groups not created via the hosting service, group management must be handled by the App server using the RC server API. Alternatively, import existing groups into the hosting service via the server API to enable client SDK management.

Group management functions

By default, RC doesn’t host user information or manage group logic, so all group logic must be implemented on the App server. Without the hosting service, features like group owner, admin, announcements, invites, and group ID search must be handled by the App. To host group and member profiles on RC, enable user information hosting.

tip
  • With the hosting service, group members receive notifications for management actions like creation, joining, removal, disbanding, and role changes. These notifications count toward group message distribution and downstream data stats.
  • For groups created without hosting, use the "import group hosting data" interface to set the group owner and permissions before using hosting features.

The table below lists basic group management interfaces provided by the IM server for non-hosted groups. Group management must be handled by the App backend via the IM server API. With the hosting service, the client SDK can manage hosted groups.

Function categoryDescriptionRC server API
Create, disband groupProvide the creator’s user ID, group ID, and group name to create a group. Disbanding a group removes all member relationships.Create group, Disband group
Join, Quit groupJoining a group allows viewing new messages. Leaving stops receiving new messages.Join group, Quit group
Modify group informationUpdate group info used in RC’s push service.Refresh group info
Query group membersGet user IDs of all members in a specified group.Query group members
Query user’s groupsGet all groups a user has joined, returning group IDs and names. RC doesn’t store group profiles. App servers must maintain group and member info. Use this interface to verify user-group relationships.Query user’s groups
Sync user’s groupsSync a user’s groups with the RC server to prevent inconsistencies. Use this interface to sync existing user-group relationships when integrating RC services.Sync user’s groups
Mute a user in a groupMute one or more users in a specified group. Muted users can receive but not send messages.Mute a user
Mute all users in a groupMute all members of a group. Only users in the mute whitelist can send messages.Mute all users
Group mute whitelistUsers in the mute whitelist can send messages even if the group is muted.Group mute whitelist

Group chat message functions

Group chat message functions are similar to one-to-one chat, sharing some APIs and configurations.

FunctionDescriptionClient APIRC server API
Send messageSend regular and media messages, like text, images, GIFs, or custom messages. Supports @ mentions.Send messageSend group chat message
Send group directed messageSend messages to one or more specified group members. Other members won’t receive the message.[Send group directed message][Send group chat directed message]
Receive messageListen and receive messages in real-time, or receive offline messages when the client comes online.Receive messageNot applicable
Group chat message read receiptAfter sending a group message, check its read status by sending a read receipt request and getting the recipient’s response.Read receipt for one-to-one and group chatNot applicable
Offline messageSupports offline message storage, configurable for 1 to 7 days. By default, all group messages within the last 7 days are stored. Adjust storage duration and message count.Manage offline message storageNot provided
Offline message pushPush notifications for new group messages when offline.Android push guideNot provided
Recall messageRecall a successfully sent message.Recall messageRecall message
Local message searchSearch locally stored messages (on mobile devices) by keyword or user.Search messageNot provided
Get historical messagesGet historical messages from the local database or remotely. Remote access requires enabling the cloud storage for one-to-one and group messages service, with a default storage duration of 6 months.Get historical messagesNot provided
Get history message logsRC server saves all conversation history messages in the app. History messages are provided as compressed log files. Use the server API to get or delete history message logs for a specific app.Not providedGet history message logs
Insert message locallyInsert a message in the local database. Locally inserted messages aren’t sent to the server or the recipient.Insert messageNot applicable
Delete messageDelete specified messages or all history messages in a conversation locally and on the server.Delete messageMessage clear
Message extension for one-to-one and group chatAdd status identifiers (extension data as KV key-value pairs) to original messages. Add, delete, and query extension information.Message extensionMessage extension for one-to-one and group chat
Custom message typeCustomize message types if built-in ones don’t meet your needs. Supports custom ordinary and media message types.Custom message typeNot applicable

By default, new group members only receive messages sent after joining. To view history messages before joining, enable these two services for your App Key (note the difference between development and production environments):

  • Enable Cloud storage for one-to-one and group messages from the Chat pricing plans page in the console. Once enabled, use RC’s message storage service for message history roaming. Available for IM Premium Edition or IM Ultimate Edition. For specific features and pricing, refer to the Billing instructions.
  • Enable New user get history messages before joining group from the Free basic features page in the console.

Group chat features

Group chat features are similar to one-to-one chat, sharing some APIs and configurations.

FeatureDescriptionClient APIRC Server API
Get conversationSDK generates conversations in the local database based on sent and received messages. Get the conversation list from the local database.Get conversationNot provided
Get unread messages in conversationGet unread messages from a specified conversation. Useful for jumping to the first unread message or displaying all unread @ messages.Get unread messages in conversationNot provided
Handle unread message count in conversationGet or clear the unread message count in a conversation for UI display.Handle unread message count in conversationNot provided
Delete conversationDelete one or more conversations from the conversation list generated by the SDK.Delete conversationNot provided
Conversation draftSave a draft to a specified conversation.Conversation draftNot provided
Typing statusSet whether to receive reminders for new messages in a specified group chat. Default is to receive reminders.Typing statusNot provided
Manage conversation tagsCreate and manage tag information data for marking and grouping conversations. Each user can create up to 20 tags. Tag information data created by app users is synchronized with the RC server.Manage conversation tagsNot provided
Set and use conversation tagsUse conversation tags to group conversations.Set and use conversation tagsNot provided
Pin conversationPin a specified conversation to the top of the conversation list.Pin conversationPin conversation
Conversation do not disturbControl whether users can receive push notifications for offline messages when the client device is offline. Supports setting do not disturb by conversation or conversation type.Do not disturb feature overviewDo not disturb feature overview
Multi-device synchronization of do not disturb/pin statusSDK provides a conversation status (pin or do not disturb) synchronization mechanism. By setting a conversation status synchronization listener, changes made on other devices can be monitored in real-time on this device.Multi-device synchronization of do not disturb/pin statusNot applicable
Multi-device synchronization of read statusActively synchronize the read status of conversations across multiple devices under the same user account.Multi-device synchronization of read statusNot applicable

Differences between chatrooms and ultra groups

Understand the differences and all features between business types through these documents: