Marcar un mensaje entrante como leído

En este fragmento de código aprenderá a marcar un mensaje entrante de WhatsApp como read. Marcar un mensaje como read significará que aparecerán marcas de verificación azules junto a ese mensaje en la interfaz de usuario de WhatsApp en lugar de marcas de verificación grises.

Marcar un mensaje entrante como leído se hace enviando un mensaje PATCH al objeto de mensaje almacenado en los servidores de Vonage, identificando el mensaje específico por su UUID. Debido a que los objetos de mensajes están geolocalizados, se debe usar una URL específica de la zona geográfica para la solicitud; esto estará presente en el cuerpo del mensaje entrante que se marcará como read.

IMPORTANTE: Si un cliente no le ha enviado un mensaje antes, la primera vez que envíe un mensaje a un usuario, WhatsApp exigirá que el mensaje contenga una plantilla. Esto se explica con más detalle en la Entender el tema de WhatsApp.

Ejemplo

A continuación encontrará la descripción de todas las variables utilizadas en cada fragmento de código:

ClaveDescripción
JWT

Used to authenticate your request. See Authentication for more information, including how to generate a JWT.

VONAGE_APPLICATION_ID

The Vonage Application ID.

VONAGE_PRIVATE_KEY_PATH

Private key path.

GEOSPECIFIC_MESSAGES_API_URL

The URL for the Geo-specific Messages API endpoint. One of https://api-eu.nexmo.com/v1/messages, https://api-us.nexmo.com/v1/messages, https://api-ap.nexmo.com/v1/messages.

GEOSPECIFIC_VONAGE_API_HOST

The hostname for the Geo-specific API endpoint. One of api-eu.nexmo.com, api-us.nexmo.com, api-ap.nexmo.com.

MESSAGE_UUID

The UUID of the specific message.

NOTA: No utilice un + o 00 cuando introduzca un número de teléfono, empiece por el prefijo del país, por ejemplo, 447700900000.

Requisitos previos

Si no tiene una solicitud, puede crear uno. Asegúrese también de configure sus webhooks.

Escriba el código

Añada lo siguiente a mark-as-read.sh:

curl -X PATCH "${GEOSPECIFIC_MESSAGES_API_URL}/${MESSAGES_MESSAGE_ID}" \
  -H "Authorization: Bearer "$JWT\
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -d $'{
    "status": "read",
  }'

Ver fuente completa

Ejecute su código

Guarde este archivo en su máquina y ejecútelo:

bash mark-as-read.sh

Pruébalo

Al ejecutar el código se realiza una petición para marcar el mensaje de entrada especificado como leído.