mailer

package module
v0.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 15, 2018 License: MIT Imports: 10 Imported by: 44

README

Mailer

Simple E-mail sender written in Go. Mailer supports rich e-mails and, optionally, *nix built'n sendmail command.

Build Status License Releases Godocs Build Status Built with GoLang Platforms

Installation

The only requirement is the Go Programming Language.

$ go get -u github.com/kataras/go-mailer

Getting Started

  • New returns a new, e-mail sender service.
  • Mailer#Send send an e-mail, supports text/html and sendmail unix command
// New returns a new *Mailer, which contains the Send methods.
New(cfg Config) *Mailer
// SendWithBytes same as `Send` but it accepts the body as raw []byte,
// it's the fastest method to send e-mails.
SendWithBytes(subject string, body []byte, to ...string) error 

// Send sends an email to the recipient(s)
// the body can be in HTML format as well.
Send(subject string, body string, to ...string) error

// SendWithReader same as `Send` but it accepts
// an io.Reader that body can be retrieved and call the `SendWithBytes`.
SendWithReader(subject string, bodyReader io.Reader, to ...string) error

// SendWithReadCloser same as `SendWithReader` but it closes the reader at the end.
SendWithReadCloser(subject string, bodyReader io.ReadCloser, to ...string) error
Configuration
// Config contains those necessary fields that Mailer needs to send e-mails.
type Config struct {
    // Host is the server mail host, IP or address.
    Host string
    // Port is the listening port.
    Port int
    // Username is the auth username@domain.com for the sender.
    Username string
    // Password is the auth password for the sender.
    Password string
    // FromAddr is the 'from' part of the mail header, it overrides the username.
    FromAddr string
    // FromAlias is the from part, if empty this is the first part before @ from the Username field.
    FromAlias string
    // UseCommand enable it if you want to send e-mail with the mail command  instead of smtp.
    //
    // Host,Port & Password will be ignored.
    // ONLY FOR UNIX.
    UseCommand bool
}
Example
$ cat example.go
package main

import "github.com/kataras/go-mailer"

func main() {
    // sender configuration.
    config := mailer.Config{
        Host:     "smtp.mailgun.org",
        Username: "postmaster",
        Password: "38304272b8ee5c176d5961dc155b2417",
        FromAddr: "postmaster@sandbox661c307650f04e909150b37c0f3b2f09.mailgun.org",
        Port:     587,
        // Enable UseCommand to support sendmail unix command,
        // if this field is true then Host, Username, Password and Port are not required,
        // because these info already exists in your local sendmail configuration.
        //
        // Defaults to false.
        UseCommand: false,
    }

    // initalize a new mail sender service.
    sender := mailer.New(config)

    // the subject/title of the e-mail.
    subject := "Hello subject"

    // the rich message body.
    content := `<h1>Hello</h1> <br/><br/> <span style="color:red"> This is the rich message body </span>`

    // the recipient(s).
    to := []string{"kataras2006@hotmail.com", "kataras2018@hotmail.com"}

    // send the e-mail.
    err := sender.Send(subject, content, to...)

    if err != nil {
        println("error while sending the e-mail: " + err.Error())
    }
}
$ go run example.go

FAQ

Explore these questions or navigate to the community chat.

Versioning

Current: v0.1.0

Read more about Semantic Versioning 2.0.0

Upgrading from version 0.0.3 to 0.1.0

One breaking change:

The Send commands accept a to ...string instead of to []string now, this is an API Change, if you got multiple to emails then just append three dots at the end ... and you'll be fine, i.e

sender := mailer.New(mailer.Config{...})
to := []string{"recipient1@example.com", "recipient2@example.com"}
sender.Send("subject", "<p>body</p>", to...)

People

The author of go-mailer is @kataras.

Contributing

If you are interested in contributing to the go-mailer project, please make a PR.

TODO
  • Add a simple CLI tool for sending emails

License

This project is licensed under the MIT License. License file can be found here.

Documentation

Overview

Package mailer is a simple e-mail sender for the Go Programming Language.

Index

Constants

View Source
const (
	// Version current version semantic number of the "go-mailer" package.
	Version = "0.1.0"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	// Host is the server mail host, IP or address.
	Host string
	// Port is the listening port.
	Port int
	// Username is the auth username@domain.com for the sender.
	Username string
	// Password is the auth password for the sender.
	Password string
	// FromAddr is the 'from' part of the mail header, it overrides the username.
	FromAddr string
	// FromAlias is the from part, if empty this is the first part before @ from the Username field.
	FromAlias string
	// UseCommand enable it if you want to send e-mail with the mail command  instead of smtp.
	//
	// Host,Port & Password will be ignored.
	// ONLY FOR UNIX.
	UseCommand bool
}

Config contains those necessary fields that Mailer needs to send e-mails.

func DefaultConfig

func DefaultConfig() Config

DefaultConfig returns the default configs for Mailer returns just an empty Config struct.

func (Config) IsValid

func (m Config) IsValid() bool

IsValid returns true if the configuration is valid, otherwise false.

type Mailer added in v0.1.0

type Mailer struct {
	// contains filtered or unexported fields
}

Mailer is the main struct which contains the nessecary fields for sending emails, either with unix command "sendmail" or by following the configuration's properties.

func New

func New(cfg Config) *Mailer

New creates and returns a new mail sender.

func (*Mailer) Send added in v0.1.0

func (m *Mailer) Send(subject string, body string, to ...string) error

Send sends an email to the recipient(s) the body can be in HTML format as well.

Note: you can change the UseCommand in runtime.

func (*Mailer) SendWithBytes added in v0.1.0

func (m *Mailer) SendWithBytes(subject string, body []byte, to ...string) error

SendWithBytes same as `Send` but it accepts the body as raw []byte, it's the fastest method to send e-mails.

func (*Mailer) SendWithReadCloser added in v0.1.0

func (m *Mailer) SendWithReadCloser(subject string, bodyReader io.ReadCloser, to ...string) error

SendWithReadCloser same as `SendWithReader` but it closes the reader at the end.

func (*Mailer) SendWithReader added in v0.1.0

func (m *Mailer) SendWithReader(subject string, bodyReader io.Reader, to ...string) error

SendWithReader same as `Send` but it accepts an io.Reader that body can be retrieved and call the `SendWithBytes`.

func (*Mailer) UpdateConfig added in v0.1.0

func (m *Mailer) UpdateConfig(cfg Config)

UpdateConfig overrides the current configuration.

Directories

Path Synopsis
cmd

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL