Skip to content

Controller

sendEmail()

sendEmail() — returns any

Available in: controller Category: Miscellaneous Functions

Sends an email using a template and an optional layout to wrap it in. Besides the Wheels-specific arguments documented here, you can also pass in any argument that is accepted by the cfmail tag as well as your own arguments to be used by the view.

NameTypeRequiredDefaultDescription
templatestringyesThe path to the email template or two paths if you want to send a multipart email. if the detectMultipart argument is false, the template for the text version should be the first one in the list. This argument is also aliased as templates.
fromstringyesEmail address to send from.
tostringyesList of email addresses to send the email to.
subjectstringyesThe subject line of the email.
layoutanynofalseLayout(s) to wrap the email template in. This argument is also aliased as layouts.
filestringnoA list of the names of the files to attach to the email. This will reference files stored in the files folder (or a path relative to it). This argument is also aliased as files.
detectMultipartbooleannotrueWhen set to true and multiple values are provided for the template argument, Wheels will detect which of the templates is text and which one is HTML (by counting the < characters).
deliverbooleannotrueWhen set to false, the email will not be sent.
writeToFilestringnoThe file to which the email contents will be written
1. Basic email to a new user
newMember = model("member").findByKey(params.member.id);

sendEmail(
    to=newMember.email,
    template="welcomeEmail",
    subject="Thank You for Joining!",
    recipientName=newMember.name,
    startDate=newMember.startDate
);

2. Multipart email (HTML + text)
sendEmail(
    to="user@example.com",
    template="welcomeEmailText, welcomeEmailHTML",
    subject="Welcome!",
    detectMultipart=true
);

3. Email with a layout
sendEmail(
    to="user@example.com",
    template="newsletter",
    layout="emailLayout",
    subject="Monthly Newsletter",
    userName="Salman"
);

4. Email with attachments
sendEmail(
    to="user@example.com",
    template="reportEmail",
    subject="Your Monthly Report",
    file="report.pdf, summary.xlsx"
);

5. Write email to a file without sending
sendEmail(
    to="user@example.com",
    template="testEmail",
    subject="Testing Email",
    writeToFile="#expandPath('./tmp/testEmail.eml')#",
    deliver=false
);