Managing Groups
Complete guide to WhatsApp group management through Evolution API Lite
Managing Groups
Evolution API Lite provides comprehensive group management capabilities, allowing you to create groups, manage participants, update settings, and handle invitations programmatically.
All group operations require authentication via API key and a valid connected instance. Group JIDs
(identifiers) always end with @g.us.
Creating Groups
Create new WhatsApp groups with initial participants and settings.
Endpoint
POST /group/{instanceName}/createRequest Body
{
"subject": "My New Group",
"participants": ["5511999999999", "5511888888888"]
}{
"subject": "Project Team",
"participants": ["5511999999999", "5511888888888", "5511777777777"],
"description": "Team collaboration group for the new project",
"promoteParticipants": true
}Parameters
subject(required): The group name/titleparticipants(required): Array of phone numbers to add as initial participantsdescription(optional): Group description textpromoteParticipants(optional): Whether to promote added participants to admin
cURL Example
curl -X POST "https://your-api-url/group/your-instance/create" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"subject": "Development Team",
"participants": ["5511999999999", "5511888888888"],
"description": "Daily standup and project updates"
}'Response
{
"id": "120363123456789012@g.us",
"subject": "Development Team",
"creation": 1640995200,
"owner": "5511999999999@s.whatsapp.net",
"participants": [
{
"id": "5511999999999@s.whatsapp.net",
"admin": "admin"
},
{
"id": "5511888888888@s.whatsapp.net",
"admin": null
}
]
}Fetching Group Information
Get All Groups
Retrieve all groups the instance is part of.
Endpoint
GET /group/{instanceName}/fetchAllGroups?getParticipants=trueParameters
getParticipants: Set to "true" to include participant details, "false" for basic info only
cURL Example
curl -X GET "https://your-api-url/group/your-instance/fetchAllGroups?getParticipants=true" \
-H "apikey: your-api-key"Get Specific Group Info
Get detailed information about a specific group.
Endpoint
GET /group/{instanceName}/findGroupInfos?groupJid={groupJid}cURL Example
curl -X GET "https://your-api-url/group/your-instance/findGroupInfos?groupJid=120363123456789012@g.us" \
-H "apikey: your-api-key"Response
{
"id": "120363123456789012@g.us",
"subject": "Development Team",
"creation": 1640995200,
"owner": "5511999999999@s.whatsapp.net",
"desc": "Daily standup and project updates",
"descOwner": "5511999999999@s.whatsapp.net",
"descId": "12345",
"restrict": false,
"announce": false,
"size": 5,
"participants": [
{
"id": "5511999999999@s.whatsapp.net",
"admin": "admin"
}
]
}Managing Participants
Get Group Participants
Retrieve the list of participants in a group.
Endpoint
GET /group/{instanceName}/participants?groupJid={groupJid}cURL Example
curl -X GET "https://your-api-url/group/your-instance/participants?groupJid=120363123456789012@g.us" \
-H "apikey: your-api-key"Update Participants
Add, remove, promote, or demote group participants.
Endpoint
POST /group/{instanceName}/updateParticipantRequest Body
{
"groupJid": "120363123456789012@g.us",
"action": "add",
"participants": ["5511777777777", "5511666666666"]
}{
"groupJid": "120363123456789012@g.us",
"action": "remove",
"participants": ["5511777777777"]
}{
"groupJid": "120363123456789012@g.us",
"action": "promote",
"participants": ["5511888888888"]
}{
"groupJid": "120363123456789012@g.us",
"action": "demote",
"participants": ["5511888888888"]
}Actions
add: Add new participants to the groupremove: Remove participants from the grouppromote: Promote participants to admin statusdemote: Remove admin status from participants
cURL Example
curl -X POST "https://your-api-url/group/your-instance/updateParticipant" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us",
"action": "add",
"participants": ["5511777777777"]
}'Updating Group Settings
Update Group Subject (Name)
Change the group name/title.
Endpoint
POST /group/{instanceName}/updateGroupSubjectRequest Body
{
"groupJid": "120363123456789012@g.us",
"subject": "New Group Name"
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/updateGroupSubject" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us",
"subject": "Updated Development Team"
}'Update Group Description
Change or remove the group description.
Endpoint
POST /group/{instanceName}/updateGroupDescriptionRequest Body
{
"groupJid": "120363123456789012@g.us",
"description": "Updated team collaboration group with new objectives"
}{
"groupJid": "120363123456789012@g.us",
"description": ""
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/updateGroupDescription" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us",
"description": "New project guidelines and daily updates"
}'Update Group Picture
Change the group profile picture.
Endpoint
POST /group/{instanceName}/updateGroupPictureRequest Body
{
"groupJid": "120363123456789012@g.us",
"image": "https://example.com/new-group-picture.jpg"
}You can provide the image as a URL or as base64 encoded data using the format:
...
cURL Example
curl -X POST "https://your-api-url/group/your-instance/updateGroupPicture" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us",
"image": "https://example.com/group-logo.png"
}'Update Group Settings
Configure group permissions and settings.
Endpoint
POST /group/{instanceName}/updateSettingRequest Body
{
"groupJid": "120363123456789012@g.us",
"action": "restrict",
"restrict": true
}{
"groupJid": "120363123456789012@g.us",
"action": "announce",
"announce": true
}Settings
restrict: When true, only admins can send messagesannounce: When true, only admins can send messages (announcement mode)
cURL Example
curl -X POST "https://your-api-url/group/your-instance/updateSetting" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us",
"action": "restrict",
"restrict": true
}'Group Invitations
Generate Invite Link
Create an invitation link for the group.
Endpoint
POST /group/{instanceName}/inviteCodeRequest Body
{
"groupJid": "120363123456789012@g.us"
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/inviteCode" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us"
}'Response
{
"inviteCode": "ABC123DEF456",
"inviteUrl": "https://chat.whatsapp.com/ABC123DEF456"
}Revoke Invite Link
Revoke the current invitation link and generate a new one.
Endpoint
POST /group/{instanceName}/revokeInviteCodeRequest Body
{
"groupJid": "120363123456789012@g.us"
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/revokeInviteCode" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us"
}'Leaving Groups
Leave Group
Remove the instance from a group.
Endpoint
POST /group/{instanceName}/leaveGroupRequest Body
{
"groupJid": "120363123456789012@g.us"
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/leaveGroup" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"groupJid": "120363123456789012@g.us"
}'If you are the group owner, leaving will transfer ownership to another admin. If no other admins exist, the group may be deleted.
Group Privacy Settings
Join by Invite Code
Join a group using an invitation code.
Endpoint
POST /group/{instanceName}/joinGroupRequest Body
{
"inviteCode": "ABC123DEF456"
}cURL Example
curl -X POST "https://your-api-url/group/your-instance/joinGroup" \
-H "Content-Type: application/json" \
-H "apikey: your-api-key" \
-d '{
"inviteCode": "ABC123DEF456"
}'Error Handling
Common errors when managing groups:
Insufficient Permissions
{
"error": true,
"message": "Insufficient permissions to perform this action",
"code": "INSUFFICIENT_PERMISSIONS"
}Group Not Found
{
"error": true,
"message": "Group not found or instance is not a participant",
"code": "GROUP_NOT_FOUND"
}Invalid Participant
{
"error": true,
"message": "One or more participants are invalid or not on WhatsApp",
"code": "INVALID_PARTICIPANTS"
}Best Practices
Always check if the instance is a member of the group before performing operations.
Ensure the instance has admin privileges for actions that require them (adding/removing participants, changing settings).
Use the WhatsApp number validation endpoint before adding participants to groups.
Avoid rapid group operations to prevent being blocked by WhatsApp.
Set up webhooks to receive notifications about group membership changes and updates.
Next Steps
- Learn about Sending Messages to groups
- Explore Chats and Contacts management
- Set up Event System webhooks for group notifications