# Astro

## Overview

This guide explains how to integrate Mailtrap with your Astro project to send emails programmatically using the Mailtrap Email API.

### Prerequisites

Before you start, make sure you have:

* [Verified your sending domain](/email-api-smtp/setup/sending-domain.md)
* [Created and saved an API key](/email-api-smtp/setup/api-tokens.md)

## Send emails using Astro and Mailtrap

To integrate Mailtrap and send emails via Astro, copy and paste the following script into your configuration:

{% code title="astro-mailtrap-integration.js" %}

```javascript
import { ActionError, defineAction } from "astro:actions";
import { MailtrapClient } from "mailtrap";

const mailtrap = new MailtrapClient({ token: 'YOUR-MAILTRAP-API-KEY-HERE' });

export const server = {
  send: defineAction({
    accept: "form",
    handler: async () => {
      try {
        const response = await mailtrap.send({
          from: { name: 'Mailtrap Test', email: 'YOUR-EMAIL-HERE' },
          to: [{ email: 'RECIPIENT-EMAIL-HERE' }],
          subject: 'Hello World',
          html: '<strong>it works!</strong>',
        });

        console.log(response);

        return response;
      } catch (error) {
        const message = error instanceof Error ? error.message : 'Unknown error';
        console.log(message);

        throw new ActionError({
          code: "BAD_REQUEST",
          message,
        });
      }
    },
  }),
};
```

{% endcode %}

### Configuration

Once you copy the script, update the following fields with your information:

* Replace `YOUR-MAILTRAP-API-KEY-HERE` with your actual Mailtrap API token in the `token:` field
* Replace `YOUR-EMAIL-HERE` with your verified sender email
* Replace `RECIPIENT-EMAIL-HERE` with the recipient's email address

### Learn more

For additional details about the Email API, refer to the [Mailtrap Email Sending API Integration guide](/email-api-smtp/setup/api-integration.md).


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.mailtrap.io/guides/integrations/astro.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
