Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ainsleyclark/go-mail
📧 A cross platform mail driver for GoLang. Featuring Mailgun, Postal, Postmark, SendGrid, SparkPost & SMTP.
https://github.com/ainsleyclark/go-mail
email go golang mail mailgun postal postmark sendgrid smtp sparkpost
Last synced: 6 days ago
JSON representation
📧 A cross platform mail driver for GoLang. Featuring Mailgun, Postal, Postmark, SendGrid, SparkPost & SMTP.
- Host: GitHub
- URL: https://github.com/ainsleyclark/go-mail
- Owner: ainsleyclark
- License: mit
- Created: 2021-04-08T11:08:51.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-06-24T17:53:23.000Z (7 months ago)
- Last Synced: 2024-10-12T04:09:20.658Z (3 months ago)
- Topics: email, go, golang, mail, mailgun, postal, postmark, sendgrid, smtp, sparkpost
- Language: Go
- Homepage:
- Size: 749 KB
- Stars: 179
- Watchers: 8
- Forks: 16
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
- awesome-github-star - go-mail
README
[![made-with-Go](https://img.shields.io/badge/Made%20with-Go-1f425f.svg)](http://golang.org)
[![Go Report Card](https://goreportcard.com/badge/github.com/ainsleyclark/go-mail)](https://goreportcard.com/report/github.com/ainsleyclark/go-mail)
[![Test](https://github.com/ainsleyclark/go-mail/actions/workflows/test.yml/badge.svg?branch=main)](https://github.com/ainsleyclark/go-mail/actions/workflows/test.yml)
[![codecov](https://codecov.io/gh/ainsleyclark/go-mail/branch/main/graph/badge.svg?token=1ZI9R34CHQ)](https://codecov.io/gh/ainsleyclark/go-mail)
[![go.dev reference](https://img.shields.io/badge/go.dev-reference-007d9c?logo=go&logoColor=white&style=flat)](https://pkg.go.dev/github.com/ainsleyclark/go-mail)
[![Twitter Handle](https://img.shields.io/twitter/follow/ainsleydev)](https://twitter.com/ainsleydev)# 📧 Go Mail
A cross-platform mail driver for GoLang. Featuring Mailgun, Postal, Postmark, SendGrid, SparkPost & SMTP.
## Overview
- ✅ Multiple mail drivers for your needs or even create your own custom Mailer.
- ✅ Direct dependency free, all requests are made with the standard lib http.Client.
- ✅ Send attachments with two struct fields, it's extremely simple.
- ✅ Send CC & BCC messages.
- ✅ Extremely lightweight.## Supported API's
- [Mailgun](https://documentation.mailgun.com/)
- [Postal](https://docs.postalserver.io/)
- [Postmark](https://postmarkapp.com/)
- [SendGrid](https://sendgrid.com/)
- [SparkPost](https://www.sparkpost.com/)
- SMTP
## Introduction
Go Mail aims to unify multiple popular mail APIs into a singular, easy to use interface. Email sending is seriously
simple and great for allowing the developer or end user to choose what platform they use.```go
cfg := mail.Config{
URL: "https://api.eu.sparkpost.com",
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
}mailer, err := drivers.NewSparkPost(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```## Installation
```bash
go get -u github.com/ainsleyclark/go-mail
```## Docs
Documentation can be found at the [Go Docs](https://pkg.go.dev/github.com/ainsleyclark/go-mail), but we have included a
kick-start guide below to get you started.### Creating a new client:
You can create a new driver by calling the `drivers` package and passing in a configuration type which is required to
create a new mailer. Each platform requires its own data, for example, Mailgun requires a domain, but SparkPost doesn't.
This is based of the requirements for the API. For more details see the [examples](#Examples) below.```go
cfg := mail.Config{
URL: "https://api.eu.sparkpost.com",
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
Client: http.DefaultClient, // Client is optional
}mailer, err := drivers.NewSparkpost(cfg)
if err != nil {
log.Fatalln(err)
}
```### Sending Data:
A transmission is required to transmit to a mailer as shown below. Once send is called, a `mail.Response` and an `error`
be returned indicating if the transmission was successful.```go
tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
Headers: map[string]string{
"X-Go-Mail": "Test",
},
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```### Response:
The mail response is used for debugging and inspecting results of the mailer. Below is the `Response` type.
```go
// Response represents the data passed back from a successful transmission.
type Response struct {
StatusCode int // e.g. 200
Body []byte // e.g. {"result: success"}
Headers http.Header // e.g. map[X-Ratelimit-Limit:[600]]
ID string // e.g "100"
Message string // e.g "Email sent successfully"
}
```### Adding attachments:
Adding attachments to the transmission is as simple as passing a byte slice and filename. Go Mail takes care of the rest
for you.```go
image, err := ioutil.ReadFile("gopher.jpg")
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "plain text",
Attachments: []mail.Attachment{
{
Filename: "gopher.jpg",
Bytes: image,
},
},
}
```## Examples
#### Mailgun
```go
cfg := mail.Config{
URL: "https://api.eu.mailgun.net", // Or https://api.mailgun.net
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
Domain: "my-domain.com",
}mailer, err := drivers.NewMailgun(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```#### Postal
```go
cfg := mail.Config{
URL: "https://postal.example.com",
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
}mailer, err := drivers.NewPostal(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```#### Postmark
```go
cfg := mail.Config{
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
}mailer, err := drivers.NewPostmark(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```#### SendGrid
```go
cfg := mail.Config{
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
}mailer, err := drivers.NewSendGrid(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```#### SMTP
```go
cfg := mail.Config{
URL: "smtp.gmail.com",
FromAddress: "[email protected]",
FromName: "Gopher",
Password: "my-password",
Port: 587,
}mailer, err := drivers.NewSMTP(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```#### SparkPost
```go
cfg := mail.Config{
URL: "https://api.eu.sparkpost.com", // Or https://api.sparkpost.com/api/v1
APIKey: "my-key",
FromAddress: "[email protected]",
FromName: "Gopher",
}mailer, err := drivers.NewSparkPost(cfg)
if err != nil {
log.Fatalln(err)
}tx := &mail.Transmission{
Recipients: []string{"[email protected]"},
CC: []string{"[email protected]"},
BCC: []string{"[email protected]"},
Subject: "My email",
HTML: "Hello from Go Mail!
",
PlainText: "Hello from Go Mail!",
}result, err := mailer.Send(tx)
if err != nil {
log.Fatalln(err)
}fmt.Printf("%+v\n", result)
```## Writing a Mailable
You have the ability to create your own custom Mailer by implementing the singular method interface shown below.
```go
type Mailer interface {
// Send accepts a mail.Transmission to send an email through a particular
// driver/provider. Transmissions will be validated before sending.
//
// A mail.Response or an error will be returned. In some circumstances
// the body and status code will be attached to the response for debugging.
Send(t *mail.Transmission) (mail.Response, error)
}
```## Debugging
To debug any errors or issues you are facing with Go Mail, you are able to change the `Debug` variable in the
`mail` package. This will write the HTTP requests in curl to stdout. Additional information will also be
displayed in the errors such as method operations.```go
mail.Debug = true
```## Development
### Setup
To get set up with Go Mail simply clone the repo and run the following:
```bash
go get github.com/vektra/mockery/v2/.../
make setup
make mocks
```## Env
All secrets are contained within the `.env` file for testing drivers. To begin with, make a copy of the `.env.example`
file and name it `.env`. You can the set the environment variables to match your credentials for the mail drivers.You can set the recipients of emails by modifying the `EMAIL` variables as show below.
- `EMAIL_TO`: Recipients of test emails in a comma delimited list.
- `EMAIL_CC`: CC recipients of test emails in a comma delimited list.
- `EMAIL_BCC`: BCC recipients of test emails in a comma delimited list.### Testing
To run all driver tests, execute the following command:
```bash
make test-driver
```To run a specific driver test, prepend the `driver` flag as show below:
```bash
make test-driver driver=sparkpost
```The driver flag can be one of the following:
- `mailgun`
- `postal`
- `postmark`
- `sendgrid`
- `smtp`
- `sparkpost`## Contributing
We welcome contributors, but please read the [contributing document](CONTRIBUTING.md) before making a pull request.
## Credits
Shout out to the incredible [Maria Letta](https://github.com/MariaLetta) for her excellent Gopher illustrations.
## Licence
Code Copyright 2022 Go Mail. Code released under the [MIT Licence](LICENCE).