Envía correos electrónicos con Mailjet

Mailjet es un servicio de correo electrónico global de terceros que brinda a los usuarios de App Engine un nivel gratuito con 25,000 correos electrónicos por mes. Además, Mailjet ofrece las siguientes características:

  • Cumplimiento con la protección de datos europea.
  • Características de correo electrónico y capacidad de entrega, como configuración de prioridad personalizada y administración de regulación automatizada.
  • Una biblioteca de recursos de API integral en Go, PHP, Nodejs, Java, Python y Ruby para administrar cuentas secundarias, autenticación, contactos, campañas, cargas útiles personalizadas, estadísticas, eventos en tiempo real y análisis mediante la API de Event.
  • Asistencia las 24 horas, todos los días, en cualquier lugar del mundo y en más de 4 idiomas.
  • Capacidad de enviar correos electrónicos desde dominios diferentes a gmail.com

Antes de comenzar

Antes de comenzar a enviar correos electrónicos con Mailjet, haz lo siguiente:

  1. Crea una cuenta de Mailjet. Como desarrollador de App Engine, puedes comenzar con 25,000 correos electrónicos gratuitos por mes.

  2. En Mailjet, agrega y verifica la dirección de correo electrónico del remitente.

  3. Toma nota de tu secreto y clave de API en tu Configuración de SMTP de Mailjet.

  4. Selecciona o crea un proyecto de GCP nuevo en Google Cloud Platform Console y, luego, asegúrate de que exista una aplicación de App Engine y de que la facturación esté habilitada:

    Ir a App Engine

    El panel se abrirá si ya existe una aplicación de App Engine en tu proyecto y si la facturación está habilitada. De lo contrario, sigue las instrucciones para seleccionar una región y habilitar la facturación.

  5. Agrega el secreto y la clave de API de Mailjet como variables del entorno a tu archivo app.yaml.

    1. Instala el paquete de Administración de socios de red de Mailjet:

      npm install node-mailjet
      
    2. Define la configuración de Mailjet, como el secreto y la clave de API, en tu archivo app.standard.yaml:

      runtime: nodejs10
      
      # The following env variables may contain sensitive information that grants
      # anyone access to your Mailjet account. Do not add this file to your source
      # control.
      env_variables:
        MJ_APIKEY_PUBLIC: <your-mj-apikey-public>
        MJ_APIKEY_PRIVATE: <your-mj-apikey-private>

    3. Solicita la biblioteca en el código de tu aplicación.

      var Mailjet = require('node-mailjet').connect(
        process.env.MJ_APIKEY_PUBLIC,
        process.env.MJ_APIKEY_PRIVATE
      );

    Envía correos electrónicos

    Para enviar un mensaje en el código de tu aplicación, haz lo siguiente:

    1. Crea un cliente de Mailjet nuevo.

    2. Especifica los detalles y el contenido del mensaje, incluidos el correo electrónico y el nombre del remitente, el asunto, el cuerpo del mensaje y los destinatarios.

    3. Recupera la respuesta del servidor para comprobar el estado del mensaje.

    Por ejemplo:

    app.post('/hello', function(req, res, next) {
      var options = {
        Messages: [
          {
            From: {
              Email: 'no-reply@appengine-mailjet-demo.com',
              Name: 'Mailjet Pilot',
            },
            To: [
              {
                Email: req.body.email,
              },
            ],
            Subject: 'Your email flight plan!',
            TextPart: 'Mailjet on Google App Engine with Node.js',
            HTMLPart: '<h3>Mailjet on Google App Engine with Node.js</h3>',
          },
        ],
      };
    
      var request = Mailjet.post('send', {version: 'v3.1'}).request(options);
    
      request
        .then(function(response, body) {
          console.log(response.statusCode, body);
          // Render the index route on success
          return res.render('index', {
            sent: true,
          });
        })
        .catch(function(err) {
          return next(err);
        });
    });

    Estadísticas

    La carga útil de respuesta de una llamada a la API de Send de Mailjet proporciona un MessageID. Puedes usar el MessageID para acceder a información y estadísticas sobre el mensaje.

    Usa la operación GET de /message para obtener información básica sobre un mensaje, como el remitente, el destinatario y el tamaño del mensaje. Para obtener más información sobre estadísticas de mensajes, incluidas las respuestas de la API de muestra, consulta la guía de API de Mailjet.

    API de Event

    La API de Event de Mailjet ofrece notificaciones en tiempo real a través de solicitudes HTTP (webhooks) de cualquier evento relacionado con los mensajes que enviaste; por ejemplo, cuándo se enviaron o cuándo se abrieron. Esta notificación de evento funciona para toda clase de mensajes, desde transacciones hasta campañas de marketing.

    Usa la API de Event para realizar acciones específicas de manera eficiente, como el registro de los mensajes de marketing enviados a tus clientes o la actualización de los contactos que anularon la suscripción en tu sistema de administración de relaciones con clientes (CRM). En lugar de sondear la API de Mailjet algunas veces al día, los datos se envían a medida que los eventos se producen, casi en tiempo real.

    También puedes agrupar los eventos, algo que resulta útil cuando se envían volúmenes más grandes. Para obtener más instrucciones, consulta la documentación de Mailjet.

    API de Parse para correos electrónicos entrantes

    También puedes recibir y analizar correos electrónicos con Mailjet, con la entrega del contenido a un webhook. Mailjet organiza toda la información para que puedas guardarla en tu CRM o base de datos.

    Al igual que la API de Event, la API de Parse notifica casi en tiempo real a un webhook específico que envía datos a tu aplicación cuando un mensaje nuevo coincide con una ruta predefinida. Los correos electrónicos se envían a tu aplicación estructurados como un paquete JSON, con toda la información útil que necesitas, como remitente, destinatario, asunto, cuerpo y encabezados.

    Para obtener más información, incluidos los campos adicionales que se envían con cada correo electrónico, y las instrucciones para la configuración y el uso del DNS, consulta la documentación de la API de Parse de Mailjet.

¿Te ha resultado útil esta página? Enviar comentarios:

Enviar comentarios sobre...

Documentación del entorno estándar de App Engine para Node.js