let config = Mailer.Config.mailgun(key: "{mailgunApi}", domain: "{mailgunDomain}", region: "{mailgunRegion}")
SendGrid
let config = Mailer.Config.sendGrid(key: "{sendGridApiKey}")
SMTP
Use the SMTP struct as a handle to your SMTP server:
let smtp = SMTP(hostname: "smtp.gmail.com", // SMTP server address
email: "user@gmail.com", // username to login
password: "password") // password to login
let config = Mailer.Config.smtp(smtp)
Register and configure the service in your apps configure method.
Mailer(config: config, registerOn: &services)
Mailer.Config is an enum and you can choose from any integrated services to be used
3/3) Send an email
let mail = Mailer.Message(from: "admin@liveui.io", to: "bobby.ewing@southfork.com", subject: "Oil spill", text: "Oooops I did it again", html: "<p>Oooops I did it again</p>")
return try req.mail.send(mail).flatMap(to: Response.self) { mailResult in
print(mailResult)
// ... Return your response for example
}
Testing
Mailcore provides a MailCoreTestTools framework which you can import into your tests to get MailerMock.
To register, and potentially override any existing “real” Mailer service, just initialize MailerMock with your services.
// Register
MailerMock(services: &services)
// Retrieve in your tests
let mailer = try! req.make(MailerService.self) as! MailerMock
MailerMock will store the last used result as well as the received message and request. Structure of the moct can be seen below:
public class MailerMock: MailerService {
public var result: Mailer.Result = .success
public var receivedMessage: Mailer.Message?
public var receivedRequest: Request?
// MARK: Initialization
@discardableResult public init(services: inout Services) {
services.remove(type: Mailer.self)
services.register(self, as: MailerService.self)
}
// MARK: Public interface
public func send(_ message: Mailer.Message, on req: Request) throws -> Future<Mailer.Result> {
receivedMessage = message
receivedRequest = req
return req.eventLoop.newSucceededFuture(result: result)
}
public func clear() {
result = .success
receivedMessage = nil
receivedRequest = nil
}
}
Support
Join our Slack, channel #help-boost to … well, get help :)
Enterprise AppStore
Core package for Einstore, a completely open source enterprise AppStore written in Swift!
We love PR’s, we can’t get enough of them … so if you have an interesting improvement, bug-fix or a new feature please don’t hesitate to get in touch. If you are not sure about something before you start the development you can always contact our dev and product team through our Slack.
#
Mailing wrapper for multiple mailing services like Mailgun, SendGrid or SMTP
Features
Install
Just add following line package to your
Package.swift
file.Usage
Usage is really simple mkey!
1/3) Configure
First create your client configuration:
Mailgun
SendGrid
SMTP
Use the
SMTP
struct as a handle to your SMTP server:SMTP using TLS
All parameters of
SMTP
struct:2/3) Register service
Register and configure the service in your apps
configure
method.Mailer.Config
is anenum
and you can choose from any integrated services to be used3/3) Send an email
Testing
Mailcore provides a
MailCoreTestTools
framework which you can import into your tests to getMailerMock
.To register, and potentially override any existing “real” Mailer service, just initialize
MailerMock
with your services.MailerMock
will store the last used result as well as the received message and request. Structure of the moct can be seen below:Support
Join our Slack, channel #help-boost to … well, get help :)
Enterprise AppStore
Core package for Einstore, a completely open source enterprise AppStore written in Swift!
Other core packages
Implemented thirdparty providers
Code contributions
We love PR’s, we can’t get enough of them … so if you have an interesting improvement, bug-fix or a new feature please don’t hesitate to get in touch. If you are not sure about something before you start the development you can always contact our dev and product team through our Slack.
Author
Ondrej Rafaj (@rafiki270 on Github, Twitter, LiveUI Slack and Vapor Slack)
License
MIT license, please see LICENSE file for more details.