https://github.com/resend/resend-node
Resend's Official Node.js SDK
https://github.com/resend/resend-node
Last synced: 4 months ago
JSON representation
Resend's Official Node.js SDK
- Host: GitHub
- URL: https://github.com/resend/resend-node
- Owner: resend
- License: mit
- Created: 2022-07-31T04:38:52.000Z (almost 4 years ago)
- Default Branch: canary
- Last Pushed: 2025-05-14T14:41:46.000Z (about 1 year ago)
- Last Synced: 2025-05-15T07:03:00.642Z (about 1 year ago)
- Language: TypeScript
- Homepage:
- Size: 36.7 MB
- Stars: 684
- Watchers: 4
- Forks: 51
- Open Issues: 66
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-email-agents - resend/resend-node
README

Framework guides
Next.js
- Remix
- Nuxt
- Express
- RedwoodJS
- Hono
- Bun
- Astro
# Resend Node.js SDK
Node.js library for the Resend API.
## Install
```bash
npm install resend
# or
yarn add resend
```
## Examples
Send email with:
- [Node.js](https://github.com/resend/resend-node-example)
- [Next.js (App Router)](https://github.com/resend/resend-nextjs-app-router-example)
- [Next.js (Pages Router)](https://github.com/resend/resend-nextjs-pages-router-example)
- [Express](https://github.com/resend/resend-express-example)
## Setup
First, you need to get an API key, which is available in the [Resend Dashboard](https://resend.com/api-keys).
```js
import { Resend } from 'resend';
const resend = new Resend('re_xxxx...xxxxxx');
```
## Usage
Send your first email:
```js
const { data } = await resend.emails.send({
from: 'you@example.com',
to: 'user@gmail.com',
replyTo: 'you@example.com',
subject: 'hello world',
text: 'it works!',
});
console.log(`Email ${data.id} has been sent`);
```
> [!NOTE]
> In order to send from your own domain, you will first need to verify your domain in the [Resend Dashboard](https://resend.com/domains).
## Send email using HTML
Send an email custom HTML content:
```js
const { data } = await resend.emails.send({
from: 'you@example.com',
to: 'user@gmail.com',
replyTo: 'you@example.com',
subject: 'hello world',
html: 'it works!',
});
console.log(`Emaill ${data.id} with customer HTML content has been sent.`);
```
## Send email using React
Start by creating your email template as a React component.
```jsx
import React from 'react';
export default function EmailTemplate({ firstName, product }) {
return (
Welcome, {firstName}!
Thanks for trying {product}. We’re thrilled to have you on board.
);
}
```
Then import the template component and pass it to the `react` property.
```jsx
import EmailTemplate from '../components/EmailTemplate';
const { data } = await resend.emails.send({
from: 'you@example.com',
to: 'user@gmail.com',
replyTo: 'you@example.com',
subject: 'hello world',
react: ,
});
console.log(`Email ${data.id} with a React template has been sent`);
```
> [!NOTE]
> If you're sending emails from a file that doesn't have JSX transpilation set up (e.g., in a `.js`/`.ts` file instead of JSX/TSX), use React's `jsx` runtime function instead of passing the component as JSX:
>
>```js
>import { jsx } from 'react/jsx-runtime'
>import EmailTemplate from '../components/EmailTemplate';
>
>await resend.emails.send({
> from: 'you@example.com',
> to: 'user@gmail.com',
> replyTo: 'you@example.com',
> subject: 'hello world',
> react: jsx(EmailTemplate, { firstName:"John", product:"MyApp" }),
>});
>```
## License
MIT License