Chat groups enable real-time messaging among multiple users.
This page shows how to use the Agora Chat SDK to manage the members of a chat group in your app.
The Agora Chat SDK provides the ChatGroup
, ChatGroupManager
, and ChatGroupEventHandler
classes for chat group management, which allows you to implement the following features:
Before proceeding, ensure that you meet the following requirements:
This section describes how to call the APIs provided by the Agora Chat SDK to implement chat group features.
The logic of adding a user to a chat group varies according to the GroupStyle
and inviteNeedConfirm
settings when creating the chat group. For details, see Create a Chat Group.
The following code sample shows how to call addMembers
to add a user to a chat group:
try {
await ChatClient.getInstance.groupManager.addMembers(groupId, members);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call removeMembers
to remove the specified member from a chat group. Once removed from the chat group, this member receives the ChatGroupEventHandler#onUserRemovedFromGroup
callback, while all the other members receive the ChatGroupEventHandler#onMemberExitedFromGroup
callback. Users can join the chat group again after being removed.
The following code sample shows how to remove a member from a chat group:
try {
await ChatClient.getInstance.groupManager.removeMembers(groupId, members);
} on ChatError catch (e) {
}
Only the chat group owner can call changeOwner
to transfer the ownership to the specified chat group member. Once the ownership is transferred, the former chat group owner becomes a regular member, and all the other chat group members receive the ChatGroupEventHandler#onOwnerChangedFromGroup
callback.
The following code sample shows how to transfer the chat group ownership:
try {
await ChatClient.getInstance.groupManager.changeOwner(groupId, newOwner);
} on ChatError catch (e) {
}
Only the chat group owner can call addAdmin
to add an admin. Once promoted to an admin, the new admin and the other chat group admins receive the ChatGroupEventHandler#onAdminAddedFromGroup
callback.
The following code sample shows how to add a chat group admin:
try {
ChatClient.getInstance.groupManager.addAdmin(groupId, memberId);
} on ChatError catch (e) {
}
Only the chat group owner can call removeAdmin
to remove an admin. Once demoted to a regular member, the former admin and the other chat group admins receive the ChatGroupEventHandler#onAdminRemovedFromGroup
callback.
The following code sample shows how to remove a chat group admin:
try {
await ChatClient.getInstance.groupManager.removeAdmin(groupId, adminId);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call blockMembers
to add the specified member to the chat group block list. Once added to the block list, this member receives the ChatGroupEventHandler#onUserRemovedFromGroup
callback, while all the other members receive the ChatGroupEventHandler#onMemberExitedFromGroup
callback. After being added to block list, this user cannot send or receive messages in the chat group. They can no longer join the chat room until they are removed from the block list.
The following code sample shows how to add a member to the chat group block list:
try {
await ChatClient.getInstance.groupManager.blockMembers(groupId, members);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call unblockMembers
to remove the specified member from the chat group block list.
The following code sample shows how to remove a member from the chat group block list:
try {
await ChatClient.getInstance.groupManager.unblockMembers(groupId, blockIds);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call fetchBlockListFromServer
to retrieve the chat group block list.
The following code sample shows how to retrieve the chat group block list:
try {
await ChatClient.getInstance.groupManager.fetchBlockListFromServer(
groupId,
pageNum: pageNum,
pageSize: pageSize,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call muteMembers
to add the specified member to the chat group mute list. Once added to the mute list, this member and all the other chat group admins or owner receive the ChatGroupEventHandler#onMuteListAddedFromGroup
callback. Once a chat group member is added to the chat group mute list, they can no longer send chat group messages, not even after being added to the chat group allow list.
The following code sample shows how to add a member to the chat group mute list:
try {
await ChatClient.getInstance.groupManager.muteMembers(
groupId,
members,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call unMuteMembers
to remove the specified member from the chat group mute list. Once removed from the chat group mute list, this member and all the other chat group admins or owner receive the ChatGroupEventHandler#onMuteListRemovedFromGroup
callback.
The following code sample shows how to remove a member from the chat group mute list:
try {
await ChatClient.getInstance.groupManager.unMuteMembers(
groupId,
members,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call fetchMuteListFromServer
to retrieve the chat group mute list from the server.
The following code sample shows how to retrieve the chat group mute list:
try {
await ChatClient.getInstance.groupManager.fetchMuteListFromServer(
groupId,
pageNum: pageNum,
pageSize: pageSize,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call muteAllMembers
to mute all the chat group members. Once all the members are muted, only those in the chat group allow list can send messages in the chat group.
The following sample code shows how to mute all the chat group members:
try {
await ChatClient.getInstance.groupManager.muteAllMembers(
groupId,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call unMuteAllMembers
to unmute all the chat group members.
The following sample code shows how to unmute all the chat group members:
try {
await ChatClient.getInstance.groupManager.unMuteAllMembers(
groupId,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call addAllowList
to add the specified member to the chat group allow list. Members in the chat group allow list can send chat group messages even when the chat group owner or admin has muted all chat group members. However, if a member is already in the chat group mute list, adding this member to the allow list does not enable them to send messages. The mute list takes precedence.
The following code sample shows how to add a member to the chat group allow list:
try {
await ChatClient.getInstance.groupManager.addAllowList(
groupId,
members,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call removeAllowList
to remove the specified member from the chat group allow list.
The following code sample shows how to remove a member from the chat group allow list:
try {
await ChatClient.getInstance.groupManager.removeAllowList(
groupId,
members,
);
} on ChatError catch (e) {
}
All chat group members can call isMemberInAllowListFromServer
to check whether they are added to the chat group allow list.
The following code sample shows how to check whether a user is on the chat group allow list:
try {
bool check = await ChatClient.getInstance.groupManager.isMemberInAllowListFromServer(
groupId,
);
} on ChatError catch (e) {
}
Only the chat group owner and admins can call fetchAllowListFromServer
to retrieve the chat group allow list.
The following code sample shows how to retrieve the chat group allow list:
try {
List<String>? list =
await ChatClient.getInstance.groupManager.fetchAllowListFromServer(
groupId,
);
} on ChatError catch (e) {
}
For details, see Chat Group Events.