Your SlideShare is downloading. ×
Action Mailer
Action Mailer
Action Mailer
Action Mailer
Action Mailer
Action Mailer
Action Mailer
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×
Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

Action Mailer

1,286

Published on

Simple Mail Transfer Protocol (SMTP), …

Simple Mail Transfer Protocol (SMTP),
Net::SMTP.start,
smtp.send_message

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
1,286
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
5
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide

Transcript

  • 1. Action Mailer
    Action Mailer is the Rails component that enables applications to send and receive e-mail. In this chapter we will see how to send an email using Rails. So lets start with creating a emails project using following command.
    C: uby> rails emails
    This will create required framework to proceed. Now we will start with configuring Action Mailer.
    Action Mailer - Configuration
    Following are the steps you have to follow to complete your configuration before proceeding with actual work:
    Go into config folder of your emails project and open environment.rb file and add the following line at the bottom of this file.
    ActionMailer::Base.delivery_method = :smtp
  • 2. This tells ActionMailer that you want to user SMTP server. You can also set it to be :sendmail if you are using a Unix-based operating system such as Mac OS X or Linux.
    Add the following lines of code to the bottom of your environment.rb as well.
    ActionMailer::Base.server_settings = {
    :address => "smtp.site.com",
    :port => 25,
    :domain => “site.com",
    :authentication => :login,
    :user_name => "username",
    :password => "password",
    }
    Replace each hash value with proper settings for your Simple Mail Transfer Protocol (SMTP) server. You can take this information from your Internet Service Provider if you already don't know. You don't need to change port number 25 and authentication type if you are using standard SMTP server.
    You may also change the default email message format. If you prefer to send email in HTML instead of plain text format, add the following line to config/environment.rb as well:
  • 3. ActionMailer::Base.default_content_type = "text/html"
    ActionMailer::Base.default_content_type could be set to "text/plain", "text/html", and "text/enriched". The default value is "text/plain".
    Next step will be to create a mailer
    Generate a mailer:
    Use the following command to generate a mailer as follows:
    C: uby> cd emails
    C: ubyemails> ruby script/generate mailer Emailer
    This will create a file emailer.rb in appmodels directory. Check the content of this file is as follows:
  • 4. class Emailer < ActionMailer::Base
    end
    Let's create one method as follows.
    class Emailer < ActionMailer::Base
    def contact(recipient, subject, message, sent_at = Time.now)
    @subject = subject
    @recipients = recipient
    @from = 'no-reply@yourdomain.com'
    @sent_on = sent_at
    @body["title"] = 'This is title'
    @body["email"] = 'sender@yourdomain.com'
    @body["message"] = message
    end
    end
    The contact method has four parameters a recipient, subject, message and a sent_at, which defines when the e-mail is sent. The method also defines six standard parameters that are a part of every ActionMailer method:
  • 5.
    • @subject defines the e-mail subject.
    • 6. @body is a Ruby hash that contains values with which you can populate the mail template. You created three key-value pairs: title, email, and message
    • 7. @recipients is a list of the people to whom the message is being sent.
    • 8. @from defines who the e-mail is from.
    • 9. @sent_on takes the sent_at parameter and sets the timestamp of the e-mail.
  • Next we will create a controller for this application as follows:
    C: ubyemails> ruby script/generate controller Emailer
    Now lets define a controller method in emailer_controller.rb which will call Model method to send actual email as follows:
    class EmailerController < ApplicationController
    def sendmail
    email = @params["email"]
    recipient = email["recipient"]
    subject = email["subject"]
    message = email["message"]
    Emailer.deliver_contact(recipient, subject, message)
    render :text => 'Message sent successfully'
    end
    end
  • 10. Now let's define our view in appviewsemailsindex.rhtml
    <h1>Send Email</h1>
    <%= start_form_tag :action => 'sendmail' %>
    <p><label for="email_subject">Subject</label>:
    <%= text_field 'email', 'subject' %></p>
    <p><label for="email_recipient">Recipient</label>:
    <%= text_field 'email', 'recipient' %></p>
    <p><label for="email_message">Message</label><br/>
    <%= text_area 'email', 'message' %></p>
    <%= submit_tag "Send" %>
    <%= end_form_tag %>

×