WhatsApp Groups API
This documentation provides the information you need for integration with the Wavy Messaging platform for managing groups through the Wavy WhatsApp Integration. The API has REST integration, using the HTTP protocol with TLS, supporting the POST method with parameters sent in JSON format.
Authentication
In order to successfully use our API, you are required to present a valid user name - or email - and the associated authentication token. While creating the request, you have to provide the following parameters on the headers:
Field
Details
Data Type
userName
Name or email valid for authentication on Wavy Messaging.
String
authenticationToken
String
Connection Details
​
​
Hostname
api-messaging.wavy.global
Port
443 (https)
Protocol
HTTPS (TLS encryption)
Authentication
username + token
Encoding
UTF-8
Sending Messages to Groups
When sending messages to groups, the request is similar to that of direct messages. Only the Destination object needs to be adapted.
POST https://api-messaging.wavy.global/v1/whatsapp/send
The request body must contain the same fields as in Sending Text Messages.
Group delivery example
Group MO
Group MOs contain the same fields as Regular MOs with the addition of waGroupId indicating to which group the message was sent, as shown in the example.
Be careful if you are replying automatically to direct messages sent to your WhatsApp account. If the waGroupId field is ignored, the MO can be mistaken for a direct message instead of a group message, and you will reply with a direct message. This way you run the risk of being charged for an HSM every time the user sends you a group message if the waGroupId field is not treated correctly.
Group message example:
Creating Groups
Create a group by providing it with a subject or title, which is the name that will appear on the chat list. In response, you will receive a group ID you will use to send messages to the group, manage the group, etc.
Unused Groups: If you have many unused groups associated with your account, you may encounter an error (due to too many groups created). You can simply clear the groups you are no longer using by leaving them.
Request
Example
POST https://api-messaging.wavy.global/v1/whatsapp/groups
The request body must contain a JSON object with the following fields:
Field
Required
Details
Type
subject
Yes
Group subject or title, limited to 25 characters
String
Response
Response example
The response to a request to create a group returns a group ID that you will use to send messages to the group, manage the group, etc. If you need to obtain the group ID at another time, see the Consulting All Groups section.
The following fields are returned in a successful response:
Field
Details
Type
creation_time
Time of creation
Integer
id
Group identified for the recently created group. It must be used to uniquely identify groups in later requests, where group_id is used.
String
Consulting All Groups
Retrieve all groups in which the customer is a participant.
Request
GET https://api-messaging.wavy.global/v1/whatsapp/groups
Response
Response example
The response returns the group IDs for all groups in which the customer is a participant. You can obtain more information on the group, such as list of participants and the group subject, using the call described in the Consulting Group Information section.
The following fields are returned in a successful response. If there are no groups, a JSON array of empty groups is returned.
Field
Details
Type
id
List of groups the customer participates in
String
Consulting Group Information
Use this call to obtain information on the group, including participant Ids, and group subject. To obtain the group icon, see the Consulting a Group Icon section.
Request
GET https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id
Response
Response example
The following fields are returned in a successful response:
Field
Details
Type
admins
String[]
creation_time
Time of group creation
Int
creator
Group creator ID
String
id
Group ID
String
participants
String[]
subject
Group subject
String
Updating Group Information
Updating information means setting a new group subject.
Request
Example
PUT https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id
The request body must contain a JSON object with the following fields:
Field
Required
Details
Type
subject
Yes
Update the group subject to this value, limited to 25 characters
String
Response
A successful response will return a 200 OK status and null or {}. If the group is not found, the response will be 404 Not Found.
Creating a Group Invite Link
You cannot directly add participants to the group. Participants can only be invited to the group. Create a link that participants can use to join your group.
Request
GET https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/invite
Response
Response example
The following fields are returned in a successful response:
Field
Details
Type
link
Group invite link
String
Once you have a link to invite participants to the group, send the link in a text message. When a user clicks the message, they will be invited to the group.
Deleting an Invite Link
Request
DELETE https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/invite
Response
A successful response will return a 200 OK status and null or {}.
Removing Group Members
Request
Example
DELETE https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/participants
The request body must contain a JSON object with the following fields:
Field
Required
Details
Type
waIds
Yes
Numbers of participants to be removed from the group
String[]
Response
A successful response will return a 200 OK status and null or {}. If the phone number is not found, the response will be 400 Bad Request.
Leaving a Group
Leaving a group means you will remove yourself from the list of group participants. The Group will continue to exist with the remaining participants.
Request
POST https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/leave
Response
A successful response will return a 200 OK status and null or {}. If the phone number is not found, the response will be 400 Bad Request.
Setting a Group Icon
Request
Example
POST https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/icon Content-Type: image/jpeg or other appropriate type
binary-image-content
In order to set a group icon, you have to upload an image from its binary content. The Content-Type header must match the image’s MIME type.
Response
A successful response will return a 200 OK status and null or {}.
Consulting a Group Icon
Request
GET https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/icon
Response
Response example
A successful response will return a 200 OK and a JSON object with the following fields. If the group does not have an associated icon, the response will be 404 Not Found.
Field
Details
Type
type
Data field type
String
mimeType
File MIME type
String
fileName
File name
String
extraData
File information
String
data
File
String
Removing a Group Icon
Request
DELETE https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/icon
Response
A successful response will return a 200 OK status and null or {}. If the group does not have an associated icon, the response will be 404 Not Found.
Adding Administrators
By default, the only administrator of a group is its creator. More administrators can be added as long as they are already group participants. To consult the participants of a group, follow the instructions in Consulting Group Information​
Request
Example
PATCH https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/admins
The request body must contain a JSON object with the following fields:
Field
Required
Details
Type
waIds
Yes
Numbers of participants who will become administrators
String[]
Response
A successful response will return a 200 OK status and null or {}. If the phone number is not found, the response will be 400 Bad Request.
Removing Administrators
Administrators can be removed so as to become regular group participants. To consult the administrators of a group, follow the instructions in Consulting Group Information.
Request
Example
DELETE https://api-messaging.wavy.global/v1/whatsapp/groups/your-group-id/admins
The request body must contain a JSON object with the following fields:
Field
Required
Details
Type
waIds
Yes
Phone numbers of the participants who will become administrators
String[]
Response
A successful response will return a 200 OK status and null or {}. If the phone number is not found, the response will be 400 Bad Request.
Last updated