Introducing Socket Firewall: Free, Proactive Protection for Your Software Supply Chain.Learn More
Socket
Book a DemoInstallSign in
Socket

@swiftpost/nest

Package Overview
Dependencies
Maintainers
0
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@swiftpost/nest

A nestjs module for @swiftpost/mail. Allows you to send emails with swiftpost.

latest
Source
npmnpm
Version
0.0.2
Version published
Maintainers
0
Created
Source

@swiftpost/nest

SwiftPost

Overview

A NestJS module for sending authentication emails using @swiftpost/mail. @swiftpost/mail is a library for sending html emails, with a special focus on authentication emails. For more information about @swiftpost/mail, see the @swiftpost/mail.

Installation

npm install @swiftpost/nest

Usage

Importing the Module

In your AppModule, import the SwiftPostModule and configure it with your SMTP settings. By default, the module will use the environment variables SMTP_HOST, SMTP_PORT, SMTP_SECURE, SMTP_USER, and SMTP_PASS to configure the SMTP connection. If SMTP_URL is set in the environment, it will be used instead. If SMTP_FROM is set, it will be used as the default sender email address.

import { Module } from "@nestjs/common";
import { SwiftPostModule } from "@swiftpost/nest";

@Module({
  imports: [
    SwiftPostModule.forRoot({
      host: process.env.EMAIL_HOST,
      port: parseInt(process.env.EMAIL_PORT || "587", 10),
      secure: process.env.EMAIL_SECURE === "true",
      auth: {
        user: process.env.EMAIL_USER,
        pass: process.env.EMAIL_PASS,
      },
      from: process.env.EMAIL_FROM,
    }),
  ],
})
export class AppModule {}

Using the Service

Inject the SwiftPostService into your controllers or services to send authentication or any other emails.

import { Controller, Post, Body } from "@nestjs/common";
import { SwiftPostService } from "@swiftpost/nest";

@Controller("email")
export class EmailController {
  constructor(private readonly swiftPostService: SwiftPostService) {}

  @Post("send")
  async sendEmail(@Body() body: any) {
    const { to, subject, html } = body;
    return this.swiftPostService.sendWelcomeEmail(
      { to, subject, html },
      {
        name: "Jon Manga",
        link: "https://swiftpost.io",
        companyName: "SwiftPost",
        logo: "https://static.mrcelleb.com/swiftpost/logo.png",
      }
    );
  }
}

Under the hood, @swiftpost/mail uses nodemailer to send emails, so you can use any of the methods like sendMail.

SwiftPostService methods

sendWelcomeEmail

Generates and sends a welcome email.

getWelcomeEmailHtml

Renders and returns the html for a welcome email.

sendConfirmationEmail

Generates and sends a confirmation email.

getConfirmationEmailHtml

Renders and returns the html for a confirmation email.

sendPasswordResetEmail

Generates and sends a password reset email.

getPasswordResetEmailHtml

Renders and returns the html for a password reset email.

sendPasswordlessLoginEmail

Generates and sends a passwordless login email.

getPasswordlessLoginEmailHtml

Renders and returns the html for a passwordless login email.

sendAcceptInvitationEmail

Generates and sends an accept invitation email.

getAcceptInvitationEmailHtml

Renders and returns the html for an accept invitation email.

sendPasswordInvitationEmail

Generates and sends a password invitation email.

getPasswordInvitationEmailHtml

Renders and returns the html for a password invitation email.

sendWelcomeWithCredentialsEmail

Generates and sends a welcome with credentials email.

getWelcomeWithCredentialsEmailHtml

Renders and returns the html for a welcome with credentials email.

sendMail

Sends an email using nodemailer's sendMail method.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Keywords

email

FAQs

Package last updated on 16 Nov 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts