Send an automated email from a workflow.
type: "io.kestra.plugin.notifications.mail.mailsend"Examples
Send an email on a failed flow execution.
id: unreliable_flow
namespace: company.team
tasks:
  - id: fail
    type: io.kestra.plugin.scripts.shell.Commands
    runner: PROCESS
    commands:
      - exit 1
errors:
  - id: send_email
    type: io.kestra.plugin.notifications.mail.MailSend
    from: hello@kestra.io
    to: hello@kestra.io
    username: "{{ secret('EMAIL_USERNAME') }}"
    password: "{{ secret('EMAIL_PASSWORD') }}"
    host: mail.privateemail.com
    port: 465 # or 587
    subject: "Kestra workflow failed for the flow {{flow.id}} in the namespace {{flow.namespace}}"
    htmlTextContent: "Failure alert for flow {{ flow.namespace }}.{{ flow.id }} with ID {{ execution.id }}"
Send an email with attachments.
id: send_email
namespace: company.team
inputs:
  - id: attachments
    type: ARRAY
    itemType: JSON
tasks:
  - id: send_email
    type: io.kestra.plugin.notifications.mail.MailSend
    from: hello@kestra.io
    to: hello@kestra.io
    attachments: {{ inputs.attachments | toJson }}
Send an email with an embedded image.
id: send_email
namespace: company.team
inputs:
  - id: embedded_image_uri
    type: STRING
tasks:
  - id: send_email
    type: io.kestra.plugin.notifications.mail.MailSend
    from: hello@kestra.io
    to: hello@kestra.io
    embeddedImages:
      - name: kestra.png
        uri: "{{ inputs.embedded_image_uri }}"
        contentType: image/png
Export Kestra audit logs to a CSV file and send it by email.
id: export_audit_logs_csv
namespace: company.team
tasks:
  - id: ship_audit_logs
    type: "io.kestra.plugin.ee.core.log.AuditLogShipper"
    lookbackPeriod: P1D
    logExporters:
      - id: file
        type: io.kestra.plugin.ee.core.log.FileLogExporter
  - id: convert_to_csv
    type: "io.kestra.plugin.serdes.csv.IonToCsv"
    from: "{{ outputs.ship_audit_logs.outputs.file.uris | first }}"
  - id: send_email
    type: io.kestra.plugin.notifications.mail.MailSend
    from: hello@kestra.io
    to: hello@kestra.io
    username: "{{ secret('EMAIL_USERNAME') }}"
    password: "{{ secret('EMAIL_PASSWORD') }}"
    host: mail.privateemail.com
    port: 465 # or 587
    subject: "Weekly Kestra Audit Logs CSV Export"
    htmlTextContent: "Weekly Kestra Audit Logs CSV Export"
    attachments:
      - name: audit_logs.csv
        uri: "{{ outputs.convert_to_csv.uri }}"
        contentType: text/csv
triggers:
  - id: schedule
    type: io.kestra.plugin.core.trigger.Schedule
    cron: 0 10 * * 5
Properties
attachments arraystring
Adds an attachment to the email message
The attachment will be shown in the email client as separate files available for download or display. Inline if the client supports it (for example, most browsers display PDF's in a popup window).
cc string
One or more 'Cc' (carbon copy) optional recipient email address. Use semicolon as delimiter to provide several addresses.
Note that each email address must be compliant with the RFC2822 format.
embeddedImages arraystring
Adds image data to this email that can be referred to from the email HTML body.
The provided images are assumed to be of MIME type png, jpg, or whatever the email client supports as valid image that can be embedded in HTML content.
from string
The address of the sender of this email
host string
The email server host
htmlTextContent string
The optional email message body in HTML text
Both text and HTML can be provided; either will be offered to the email client as alternative content. Email clients that support it, will favor HTML over plain text and ignore the text body completely.
password string
The email server password
plainTextContent string
The optional email message body in plain text
Both text and HTML can be provided; either will be offered to the email client as alternative content. Email clients that support it, will favor HTML over plain text and ignore the text body completely.
port integerstring
The email server port
sessionTimeout integerstring
10000Integer value in milliseconds. Default is 10000 milliseconds, i.e. 10 seconds
It controls the maximum timeout value when sending emails.
subject string
The optional subject of this email
to string
Email address(es) of the recipient(s). Use semicolon as delimiter to provide several email addresses.
Note that each email address must be compliant with the RFC2822 format.
transportStrategy string
SMTPSSMTPSMTPSSMTP_TLSSMTP_OAUTH2The optional transport strategy
Will default to SMTPS if left empty
username string
The email server username
