Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/svtslv/nestjs-mailer

Mailer module for NestJS
https://github.com/svtslv/nestjs-mailer

mailer nest nestjs nodemailer

Last synced: 3 months ago
JSON representation

Mailer module for NestJS

Awesome Lists containing this project

README

        

# NestJS Mailer

NPM Version
Package License

## Table of Contents

- [Description](#description)
- [Installation](#installation)
- [Examples](#examples)
- [License](#license)

## Description
Integrates Nodemailer with Nest

## Installation

```sh
npm install nestjs-mailer nodemailer handlebars
```

Hint: handlebars is an optional dependency, if you want to use the template helper, you must install it.

```sh
npm install -D @types/nodemailer
```

You can also use the interactive CLI

```sh
npx nestjs-modules
```

## Examples

### MailerModule.forRoot(options, connection?)

```ts
import { Module } from '@nestjs/common';
import { MailerModule } from 'nestjs-mailer';
import { AppController } from './app.controller';

@Module({
imports: [
MailerModule.forRoot({
config: {
transport: 'smtp://login:[email protected]',
// transport: {
// host: 'smtp.mailtrap.io',
// port: 587,
// secure: false,
// auth: {
// user: 'login',
// pass: 'password',
// }
// },
// defaults: {
// from: '"Sviatoslav" ',
// },
},
}),
],
controllers: [AppController],
})
export class AppModule {}
```

### MailerModule.forRootAsync(options, connection?)

```ts
import { Module } from '@nestjs/common';
import { MailerModule } from 'nestjs-mailer';
import { AppController } from './app.controller';

@Module({
imports: [
MailerModule.forRootAsync({
useFactory: () => ({
config: {
transport: 'smtp://login:[email protected]',
// transport: {
// host: 'smtp.mailtrap.io',
// port: 587,
// secure: false,
// auth: {
// user: 'login',
// pass: 'password',
// }
// },
// defaults: {
// from: '"Sviatoslav" ',
// },
},
}),
}),
],
controllers: [AppController],
})
export class AppModule {}
```

### InjectMailer(connection?)

```ts
import { Controller, Get, } from '@nestjs/common';
import { InjectMailer, Mailer, template } from 'nestjs-mailer';

@Controller()
export class AppController {
constructor(
@InjectMailer() private readonly mailer: Mailer,
) {}

@Get()
async getHello() {
this.mailer.sendMail({
from: '"Sviatoslav" ',
to: '[email protected]',
subject: 'Hello ✔',
text: 'Hello John',
html: template('src/mailer/hello.hbs', { name: 'John' })
}).catch(e => console.log(e));
}
}
```

## License

MIT