Enviar una plantilla de autenticación de WhatsApp

En este fragmento de código aprenderá a enviar una plantilla de autenticación de WhatsApp utilizando la Messages API.

WhatsApp ha actualizado recientemente las normas de uso de las plantillas de autenticación, que ahora deben incluir un COPY_CODE o ONE_TAP botón. Dado que contiene un botón, una plantilla de autenticación se considera una plantilla interactiva. Al enviar plantillas interactivas a través de la API de Messages API de Vonage, deben enviarse con un botón message_type de custom en lugar de template.

La plantilla To se envía mediante el objeto personalizado Messages. El objeto personalizado toma una sección parcial de la solicitud original de la API de WhatsApp y la envía directamente a WhatsApp.

Las plantillas de mensajes multimedia de WhatsApp constan de una estructura de cuerpo, pie de página y botones.

Nota: En caso de que esté intentando enviar una plantilla Auth con el botón One-Tap y si no realiza un apretón de manos antes de enviar el mensaje, o el mensaje no supera una comprobación de elegibilidad, el mensaje entregado mostrará un botón de copia de código en lugar de un botón de una pulsación.

Ejemplo

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

ClaveDescripción
VONAGE_APPLICATION_ID

The Vonage Application ID.

VONAGE_APPLICATION_PRIVATE_KEY_PATH

Private key path.

WHATSAPP_NUMBER

The WhatsApp number that has been allocated to you by Vonage. For sandbox testing the number is 14157386102.

VONAGE_NUMBER

Refer to WHATSAPP_NUMBER above.

TO_NUMBER

Replace with the number you are sending to. E.g. 447700900001

WHATSAPP_AUTH_TEMPLATE_NAME

The name of the Authentication template created in your WhatsApp Business Account.

OTP

A One-Time Password

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 send-authentication-template.sh:

curl -X POST "${MESSAGES_API_URL}" \
  -H "Authorization: Bearer "$JWT\
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -d $'{
    "to": "'${MESSAGES_TO_NUMBER}'",
    "from": "'${WHATSAPP_SENDER_ID}'",
    "channel": "whatsapp",
    "message_type": "custom",
    "custom": {
      "type": "template",
      "template": {
        "name": "'${WHATSAPP_TEMPLATE_NAME}'",
        "language": {
          "policy": "deterministic",
          "code": "en"
        },
        "components": [
          {
            "type": "body",
            "parameters": [
              {
                "type": "text",
                "text": "'${WHATSAPP_OTP}'"
              }
            ]
          },
          {
            "type": "button",
            "sub_type": "url",
            "index": "0",
            "parameters": [
              {
                "type": "text",
                "text": "'${WHATSAPP_OTP}'"
              }
            ]
          }
        ]
      }
    }

Ver fuente completa

Ejecute su código

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

bash send-authentication-template.sh

Pruébalo

Al ejecutar el código, se envía una plantilla de autenticación de WhatsApp al número de destino.

Para más información