Skip to main content
Version: LOC v0.9 (legacy)

Mail Agent

import { MailAgent, MailAgentClient, Mail } from "@fstnetwork/loc-logic-sdk";

Sending emails with a SMTP server.

Availability

  • ✓ Generic logic
  • ✗ Aggregator logic
info

This agent requires agent configuration. See tutorial for details.

The mail agent supports StartTLS.

Acquire Mail Client

async MailAgent.acquire(configurationName: string): Promise<MailAgentClient>

Returns a MailAgentClient object based on provided agent configuration name, which connects to a pre-defined SMTP server with confidential information.

The configuration name is the reference field set in Studio or name field set in CLI config files.

Throws an error if the configuration cannot be found.

Example

const mailClient = await MailAgent.acquire("my-mail-configuration");

Send a Mail

async mailClient.send(mail: Mail.Mail): Promise<any>

Send an email. See the example below.

Example

const mailClient = await MailAgent.acquire("my-mail-configuration");

// mail body
const mail_body = `Nothing travels faster
than the speed of light,
with the possible exception of bad news,
which obeys its own special laws.`;

// get a new mail object
const mail = new Mail.Mail()
// required fields
.setSender("sender@example.com", "sender name")
.setSubject("Mail subject")
.setReceivers("receiver1@example.com", "receiver 1 name")
.setReceivers("receiver2@example.com", "receiver 2 name")
.setBody(mail_body)

// optional fields
.setReplyTo("reply@example.com", "reply name")
.setCC("cc@example.com", "cc name")
.setBCC("bcc@example.com", "bcc name");

// end of mail object
// send the mail
await mailClient?.send(mail);
tip

You can also omit the second name parameter in setSender, setReceivers, setReplyTo, setCC and setBCC.