Home > docs > plugins v2 > SMTP Task
To send email notifications as a step of a flow, use the smtp
task.
Parameters
smtpParams
- SMTP server settings including:
host
- String
, server addressport
- Number
, server portmail
- mail settings including:
from
- String
, sender’s email addressto
- String
or List
, Comma-separated email addresses or list of email addresses to receive the emailreplyTo
- optional String
, reply-to email addresscc
- optional String
or List
, Comma-separated email addresses or list of email addresses to carbon copybcc
- optional, String
or List
, Comma-separated email addresses or list of email addresses to blind carbon copysubject
- String
, email subjectmessage
- String
, plaintext email body (optional if using template
)template
- optional String
, template file path in working directoryattachments
- optional List
of file attachmentsTo make use of the smtp
task, first declare the plugin in dependencies
under
configuration
. This allows you to add an smtp
task in any flow as a step.
configuration:
dependencies:
- mvn://com.walmartlabs.concord.plugins.basic:smtp-tasks:2.20.0
This adds the task to the classpath and allows you to invoke the task in a flow:
flows:
default:
- task: smtp
in:
mail:
from: [email protected]
to: [email protected]
subject: "Hello from Concord"
message: "My message"
The debug
- boolean parameter, if true the plugin logs additional debug
information, defaults to false
.
The mail
input parameters includes the parameters from
to specify the email
address to be used as the sender address, to
for the recipient address,
subject
for the message subject and message
for the actual message body.
The attachments
parameter accepts a list of file paths or attachment
definitions. File paths must be relative to the process’ working directory.
flows:
default:
- task: smtp
in:
mail:
from: [email protected]
# ...other params...
attachments:
# simple file attachment
- "myFile.txt"
# or get specific
- path: "test/myOtherFile.txt"
disposition: "attachment"
description: "my attached file"
name: "my.txt"
The above example attaches two files from the process working directory,
myFile.txt
from the directory itself and myOtherFile.txt
from the test
directory. The description
and name
parameters are optional. The
disposition
parameter allows the values attachment
or inline
. Inline
inserts the file as part of the email message itself.
You can add cc
and bcc
recipient email addresses, and specify
a replyTo
address.
In the to
, cc
, and bcc
fields, you can handle multiple addresses, either as
a comma separated list shown in the following cc
configuration, or a YAML array
as in the following bcc
configuration:
flows:
default:
- task: smtp
in:
mail:
from: [email protected]
to: [email protected]
cc: [email protected],[email protected],[email protected]
bcc:
- [email protected]
- [email protected]
- [email protected]
replyTo: [email protected]
subject: "Hello from Concord"
message: "My message"
To send an email to the process initiator, you can use the
attribute initiator.attributes.mail
.
Concord supports the use of a separate file for longer email messages. As an
alternative to message
, specify template
and point to a file in your project
that contains the message text:
- task: smtp
in:
mail:
template: mail.mustache
The template engine Mustache is used to process email template files, so you can use any variables from the Concord process context in the message.
When creating content in a template file, you can reference any variable that is
defined in the flow using double open {
and closing curly braces }
in the
template file:
The process for this project was started by {{ initiator.displayName }}.
When a template file name ends with .html
, the email body is sent HTML-formatted.
- task: smtp
in:
mail:
from: [email protected]
to: [email protected]
subject: "Howdy!"
template: "mail.mustache.html"
For email notifications with the smtp
task to work, the connections details
for your SMTP server must specified using one of the following options:
In most cases, a Concord administrator takes care of this configuration on a global default process configuration.
The simplest and cleanest way to activate the task and specify the SMTP server connection details is to set up a default process configuration policy:
configuration/dependencies
, specify the smtp-tasks
plugin.smtpParams
as an argument
and specify the SMTP server host
and
port
as attributes:configuration:
dependencies:
- mvn://com.walmartlabs.concord.plugins.basic:smtp-tasks:2.20.0
arguments:
smtpParams:
host: smtp.example.com
port: 25
In some cases you might want to specify the SMTP server in your own Concord flow, instead of using the global configuration. This approach is required if no global configuration is set up.
First, add the plugin as a dependency:
configuration:
dependencies:
- mvn://com.walmartlabs.concord.plugins.basic:smtp-tasks:2.20.0
Then set the smtpParams
with the connection details for any usage of
the smtp
task:
flows:
default:
- task: smtp
in:
smtpParams:
host: smtp.example.com
port: 25
mail:
from: [email protected]
to: [email protected]
subject: "Hello from Concord"
message: "My message"
Consider using a global variable to store the parameters in case of multiple
smtp
invocations.