Package Exports
- nuxt-nodemailer
Readme
nuxt-nodemailer
Adds nodemailer to the Nuxt3
This module can be used to send emails only from the server-side in Nuxt3.
Features
- Auto import server composable
useNodeMailer() - Add
sendEmail()which inheritsfromargument - Expose
nodemaileroriginal instance - Using env variables for configuration
Install
# Using pnpm
pnpm add -D nuxt-nodemailer nodemailer
# Using yarn
yarn add --dev nuxt-nodemailer nodemailer
# Using npm
npm install --save-dev nuxt-nodemailer nodemailerConfiguration
Add nuxt-nodemailer to the modules sections of your nuxt.config.js.
the configuration uses the same options as nodemailer you can find them here
export default {
modules: [
'nuxt-nodemailer'
],
nodemailer: {
from: '"John Doe" <john@doe.com>',
host: 'smtp.mailtrap.io',
port: 465,
secure: true,
auth: {
user: 'john@doe.com',
pass: '',
},
},
}Environment Variables
It's recommended to use environment variables for sensitive information like pass.
each option in the nodemailer configuration can be overwritten using environment variables. It has to be prefixed with NUXT_NODEMAILER_ and in uppercase.
For example, to overwrite the auth.pass and from options you can use the following environment variables:
NUXT_NODEMAILER_AUTH_PASS=yourpassword
NUXT_NODEMAILER_FROM="..."Warning: You can overwrite only existing options in the
nodemailerconfiguration.
Usage
In the server event handler, you can use the useNodeMailer composable to send emails.
export default defineEventHandler(() => {
const { sendMail } = useNodeMailer()
return sendMail({ subject: 'Nuxt + nodemailer', text: 'Hello from nuxt-nodemailer!', to: 'petr@kleinpetr.com' })
})the benefit of using
sendMailis that it automatically inherits thefromargument from the configuration and you don't have to specify it every time.
You can also use the transport with your config options or create brand new transport using nodemailer instance directly.
export default defineEventHandler(() => {
const { transport, nodemailer } = useNodeMailer()
// you can create a new transport
return nodemailer.createTransport(...)
// or use the existing one
return transport.sendMail(...)
})