# SendGrid Mailer
[data:image/s3,"s3://crabby-images/68858/68858d7ba7d3660a7aee69de71e52013705c6331" alt="Gem Version"](https://badge.fury.io/rb/send_grid_mailer)
[data:image/s3,"s3://crabby-images/9bad1/9bad1a851223f053e8c43495845c892d3e12e587" alt="Build Status"](https://travis-ci.org/platanus/send_grid_mailer)
[data:image/s3,"s3://crabby-images/3e270/3e27053079c8b62756cd45464447d8bbeeaf8292" alt="Coverage Status"](https://coveralls.io/github/platanus/send_grid_mailer)
Is an Action Mailer adapter for using SendGrid in a Rails application and
It's built on top of the [sengrid-ruby](https://github.com/sendgrid/sendgrid-ruby) gem.
## Installation
Add to your Gemfile:
```ruby
gem "send_grid_mailer"
```
```bash
bundle install
```
In your environment file you need to add:
```ruby
config.action_mailer.delivery_method = :sendgrid
config.action_mailer.sendgrid_settings = {
api_key: "YOUR-SENDGRID-API-KEY"
}
```
## Usage
With this adapter you will be able to:
#### Set E-mail's Subject
```ruby
class TestMailer < ApplicationMailer
def my_email
set_subject("My Subject")
mail
end
def my_email # through mail method's params
mail(subject: "My Subject")
end
end
```
#### Set E-mail's Body
```ruby
class TestMailer < ApplicationMailer
def my_email
set_content("Body")
mail
end
def my_email # through mail method's params
mail(body: "
Body
", content_type: "text/html")
end
end
```
#### Set E-mail's Sender
```ruby
class TestMailer < ApplicationMailer
default from: "default-sender@platan.us"
def my_email
set_sender("override-default-sender@platan.us")
mail
end
def my_email # through mail method's params
mail(from: "override@platan.us", body: "Body")
end
end
```
#### Set E-mail's Recipients
```ruby
class TestMailer < ApplicationMailer
def my_email
set_recipients(:to, "r1@platan.us", "r2@platan.us")
set_recipients(:cc, ["r4@platan.us"])
set_recipients(:bcc, "r5@platan.us")
mail
end
def my_email # through mail method's params
mail(
to: ["r1@platan.us", "r2@platan.us"],
cc: ["r4@platan.us"],
bcc: "r5@platan.us"
)
end
end
```
#### Set E-mail's Headers
```ruby
class TestMailer < ApplicationMailer
def my_email
headers["HEADER-1"] = "VALUE-1"
headers["HEADER-2"] = "VALUE-2"
mail
end
def my_email # through mail method's params
mail(headers: { "HEADER-1" => "VALUE-1", "HEADER-2" => "VALUE-2" })
end
end
```
#### Set E-mail's Attachments
```ruby
class TestMailer < ApplicationMailer
def my_email # using Action Mailer method
attachments["platanus.png"] = File.read("file-path")
mail
end
def my_email # using this gem method
file = File.read("file-path")
add_attachment(file, "platanus.png", "image/png", "inline")
mail
end
end
```
#### Set SendGrid's Template
```ruby
class TestMailer < ApplicationMailer
def my_email
set_template_id("XXX")
mail
end
def my_email # through template's name
set_template_name("my template name")
mail
end
def my_email # through mail method's params
mail(template_id: "XXX")
end
end
```
#### Add Substitutions in SendGrid's Template
```ruby
class TestMailer < ApplicationMailer
def my_email
substitute "%key1%", "value1"
substitute "%key2%", "value2"
mail
end
end
```
> Remember: you need to specify al least: `body`, `template`, `template name` or a Rails template.
## Testing
To run the specs you need to execute, **in the root path of the gem**, the following command:
```bash
bundle exec guard
```
You need to put **all your tests** in the `/send_grid_mailer/spec/dummy/spec/` directory.
## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request
## Credits
Thank you [contributors](https://github.com/platanus/send_grid_mailer/graphs/contributors)!
SendGrid Mailer is maintained by [platanus](http://platan.us).
## License
SendGrid Mailer is © 2016 platanus, spa. It is free software and may be redistributed under the terms specified in the LICENSE file.