Send Email Plugin 
Send e-mails through an e-mail form.
 
  Usage 
 
-  Create a form on the page that invokes the sendemailscript
-  Add a "to" field and a submit button
-  Make sure to fill in allowed 'to' addresses in setting {Permissions}{Allow}{MailTo}in configure
  Example 
<form enctype="application/x-www-form-urlencoded" name="mailform" action="%SCRIPTURL{sendemail}%/%WEB%/%TOPIC%" method="POST">
<input type="hidden" name="subject" value="hello!" />
Send to: <input class="foswikiInputField" name="to" size="30" type="text" value="email address..." /> 
<input type="submit" class="foswikiSubmit" value="Send" />
</form>
   Usage details 
Sending emails through a form may contain these elements: 
-  An HTML form
-  Allow/restrict settings in configure
-  Optionally a feedback message macro SENDEMAIL
-  Optionally a custom email template
The HTML form encapsulates the data to be sent, each part passed as a form field, either an input field or hidden field.
<form enctype="application/x-www-form-urlencoded" name="mailform" action="%SCRIPTURL{sendemail}%/%WEB%/%TOPIC%" method="POST">
... fields ...
<input type="submit" class="foswikiSubmit" value="Send" />
</form>
Note, that the 
from, 
to and 
cc parameters can be either an email address or a wiki user name, in which case the email address of that wiki user is used instead.
	
		
			| Element   | Required | Description | Example | 
	
	
		
			| tofield | Required | Text input field or hidden field | <input class="foswikiInputField" name="to" size="30" type="text" /> | 
		
			| successsectionfield | Optional | (Presumably) hidden field. Will display a named section (that you define using STARTSECTIONandENDSECTIONafter a successful sent. | <input type="hidden" name="successsection" value="feedbackYes" /> | 
		
			| subjectfield | Optional | Text input field or hidden field | <input class="foswikiInputField" name="subject" size="30" type="text" /> | 
		
			| redirecttofield | Optional | (Presumably) hidden field. If passed, after a sent success or error, the page gets redirected to this url. | <input type="hidden" name="redirectto" value="%SCRIPTURL{view}%/%WEB%/MailFeedback" /> | 
		
			| name,method | Required | A form must have a name; send method is POST. |  | 
		
			| mailtemplatefield | Optional | (Presumably) hidden field. See Email template | <input type="hidden" name="mailtemplate" value="Main.MailTemplate" /> | 
		
			| fromfield | Optional | Text input field or hidden field. May be used to specify a different sender, otherwise defaults to the mail address of the current user. | <input class="foswikiInputField" name="from" size="30" type="text" /> | 
		
			| errorsectionfield | Optional | (Presumably) hidden field. Will display a named section (that you define using STARTSECTIONandENDSECTIONafter an unsuccessful sent. | <input type="hidden" name="errorsection" value="feedbackNo" /> | 
		
			| ccfield | Optional | Text input field or hidden field | <input class="foswikiInputField" name="cc" size="30" type="text" /> | 
		
			| bodyfield | Optional | Textarea or hidden field | <textarea class="foswikiInputField" cols="70" name="body" rows="6" style="width:100%"></textarea> | 
		
			| action | Required | Must call sendemailscript | action="%SCRIPTURL{sendemail}%/%WEB%/%TOPIC%" | 
	
  Allow/restrict settings 
To prevent this plugin to be used as open email relay, by default sending emails is prohibited. To send out mails, first set the mail addresses you want to allow to send to in 
configure. Each can be a list of comma separated regular expressions that emails are checked against before allowing the mail to be sent. 
-  {Plugins}{SendEmailPlugin}{Permissions}{Allow}{MailTo}- enter.*to allow to send to anyone
-  {Plugins}{SendEmailPlugin}{Permissions}{Deny}{MailTo}
Other preferences can be set depending on your needs: 
-  {Plugins}{SendEmailPlugin}{Permissions}{Allow}{MailFrom}
-  {Plugins}{SendEmailPlugin}{Permissions}{Deny}{MailFrom}
-  {Plugins}{SendEmailPlugin}{Permissions}{Allow}{MailCc}
-  {Plugins}{SendEmailPlugin}{Permissions}{Deny}{MailCc}
Each 
Deny is evaluated after each 
Allow, so Deny settings overrule Allow settings.
  Examples of allow/restrict settings 
 
-  Allow to send to: 
-  Set {SendEmailPlugin}{Permissions}{Allow}{MailTo}to:
-  john@tar.comto only allow to send mails to John
-  john@tar.com|mary@look.cato allow to send mails to John and Mary
-  .*@tar.comto send mails to any address at @tar.com
-  .*@tar.com,mary@.*to send mails to any address at @tar.com and to all Marys in the world
 
 
-  Deny to send to: 
-  Set {SendEmailPlugin}{Permissions}{Deny}{MailTo}to:
-  .*@tar.comto deny to any address at @tar.com
-  .*to deny any address (no emails will be sent)
 
 
The same rules apply for 
{MailFrom} and 
{MailCc}.
  Feedback notifications 
Use the macro 
SENDEMAIL to write a feedback message on the page, on the position of the macro.
Simply:
%SENDEMAIL%
will write a feedback message (if any), using the default message strings set in 
configure.
The message can be tailored using SENDEMAIL parameters:
	
		
			| Parameter | Description | Example | 
	
	
		
			| feedbackSuccess | Message string in case of successful send. | feedbackSuccess="Request sent, we'll contact you shortly." | 
		
			| feedbackError | Message string in case of unsuccessful send. | feedbackError="Could not send your message, please contact us." | 
		
			| format | A format string. Use $messageas placeholder for the actual feedback message. | format="<div class=\"foswikiNotification\">$message</div>" | 
	
  Feedback notification example 
%SENDEMAIL{
feedbackSuccess="Request sent, we'll contact you shortly."
feedbackError="Could not send your message, please contact us."
format="<div class=\"foswikiNotification\">$message</div>"
}%
  Email template 
To customize the email, including its header, create a new template topic and pass the topic name in a 
mailtemplate form field. The default template is 
SendEmailPluginTemplate:
From: %FROM%
To: %TO%
CC: %CC%
Subject: %SUBJECT%
Auto-Submitted: auto-generated
%BODY%
The tags 
%FROM%, 
%TO%, 
%CC%, 
%SUBJECT% and 
%BODY% are replaced with the respective form values when the email is created.
For a template topic named 
MailTemplate you can either pass the name 
Mail or 
MailTemplate.
The search path for templates always starts in the current web.
  Examples 
<form enctype="application/x-www-form-urlencoded" name="mailform1" action="%SCRIPTURL{sendemail}%/%WEB%/%TOPIC%" method="POST">
<div class="foswikiFormSteps">
<div class="foswikiFormStep">
<h3>To:</h3>
<input class="foswikiInputField" id="to" name="to" size="30" type="text" value="%URLPARAM{"to"}%" />
</div>
<div class="foswikiFormStep">
<h3>CC:</h3>
<input type="text" class="foswikiInputField" id="cc" name="cc" size="30"  value="%URLPARAM{"cc"}%" />
</div>
<div class="foswikiFormStep">
<h3>Subject:</h3>
<input type="text" class="foswikiInputField" id="subject" name="subject" size="70" value="%URLPARAM{"subject"}%" />
</div>
<div class="foswikiFormStep">
<h3>Message:</h3>
<textarea class="foswikiInputField" cols="70" name="body" rows="6" style="width:100%">%URLPARAM{"body"}%</textarea>
</div>
<div class="foswikiFormStep">
<input type="submit" class="foswikiSubmit" value="Send" />
</div>
</div>
</form>
%SENDEMAIL{
feedbackSuccess="Request sent, we'll contact you shortly."
feedbackError="Could not send your message, please contact us."
format="<div class=\"foswikiNotification\">$message</div>"
}%
 
This form asks for user information and validates that the fields are filled.
%STARTFORM{
name="mailForm"
action="%SCRIPTURL{sendemail}%/%WEB%/%TOPIC%"
method="POST"
}%
%FORMELEMENT{
   name="Subject"
   type="hidden"
   default="This is a test"
}%%FORMELEMENT{
   name="Name"
   type="text"
   mandatory="on"
   validate="nonempty"
   title="Name (First and Last):"
}%%FORMELEMENT{
   name="To"
   type="text"
   mandatory="on"
   validate="email"
   title="E-mail Address:"
}%%FORMELEMENT{
   name="body"
   type="textarea"
   rows="10"
   cols="80"
   cssclass="foswikiHidden"
   default="From: $Name
Email: $Email"
}%%FORMELEMENT{
   type="submit"
   buttonlabel="Send"
}%
%ENDFORM%
%SENDEMAIL{feedbackSuccess="Request sent, we'll contact you shortly." feedbackError="Could not send your message, please contact us." }%
 
%STARTFORM{
name="mailForm"
action="https://manual.jointcommission.org/bin/sendemail/System/SendEmailPlugin"
method="POST"
}%
This is a test%FORMELEMENT{
   name="Name"
   type="text"
   mandatory="on"
   validate="nonempty"
   title="Name (First and Last):"
}%%FORMELEMENT{
   name="To"
   type="text"
   mandatory="on"
   validate="email"
   title="E-mail Address:"
}%From: $Name
Email: $Email%FORMELEMENT{
   type="submit"
   buttonlabel="Send"
}%
%ENDFORM%
  FAQ 
  How do I create linebreaks in the email body? 
Use the token 
$n to create newlines.
If you have a 
data form with the fields 
Title and 
Summary and want to post the values of these fields in the body of the e-mail, eiter: 
-  put them in a hidden field:   
<input type="hidden" name="body" value="Title: %FORMFIELD{"Title"}%, Summary: %FORMFIELD{"Summary"}%" />
-  preserve linebreaks by putting them in a textarea:   
<textarea name="body" class="foswikiHidden" cols="80" rows="6">
Title: %FORMFIELD{"Title"}%
Summary: %FORMFIELD{"Summary"}%
</textarea>
  Plugin test 
 
-  SendEmailPlugin is enabled.
  Plugin Settings    
Plugin settings are set in 
configure.
Note: by default any emailing is prohibited. Change the settings in configure to set to which addresses you allow mails to be sent from and to.
  CSS classes 
HTML elements with these style names are written to the default feedback. 
	
		
			| Class name | Note | 
	
	
		
			| sendEmailPluginNotification | Used for feedback after sending a mail | 
		
			| sendEmailPluginError | Styles sendEmailPluginNotificationin case of an error | 
	
  Installation Instructions 
You do not need to install anything in the browser to use this extension. The following instructions are for the administrator who installs the extension on the server.
Open configure, and open the "Extensions" section. "Extensions Operation and Maintenance" Tab → "Install, Update or Remove extensions" Tab.  Click the "Search for Extensions" button.  
Enter part of the extension name or description and press search.   Select the desired extension(s) and click install. If an extension is already installed, it will 
not show up in the
search results.
You can also install from the shell by running the extension installer as the web server user: (Be sure to run as the webserver user, not as root!)
cd /path/to/foswiki
perl tools/extension_installer <NameOfExtension> install
If you have any problems, or if the extension isn't available in 
configure, then you can still install manually from the command-line. See 
https://foswiki.org/Support/ManuallyInstallingExtensions for more help.
  Change History 
	
		
			| 20 May 2022 | 2.00 Michael Daum: remove dependency on CGI for rendering html; use utf8 encoding when sending emails; support ajax-sending mail forms | 
		
			| 09 Sep 2017 | 1.55 fix switchboard configuration | 
		
			| 15 Mar 2013 | 1.54 Michael Daum: don't send an empty CC; fix adding css to the header | 
		
			| 25 Aug 2011 | 1.53 Fixes a bug in the example form. | 
		
			| 13 Mar 2010 | 1.52 Improved error feedback and documentation. | 
		
			| 28 Feb 2010 | 1.51 Added forgotten Config.specfile. | 
		
			| 08 Jan 2010 | 1.5 Arthur Clemens: Improved error feedback; added formatparameter; moved the mail template to a topic; changed paramtemplatetomailtemplate. | 
		
			| 03 Jan 2010 | 1.42 Arthur Clemens: Added configure settings to download. | 
		
			| 29 Mar 2009 | 1.41 Arthur Clemens: Removed default restrictions in Denysettings so that only theAllowsetting needs to be set to send emails. | 
		
			| 21 Mar 2009 | 1.4 Arthur Clemens: Moved topic and hardcoded settings to configure. | 
		
			| 12 Mar 2009 | 1.3 Foswiki version. | 
		
			| 06 Nov 2008 | 1.23 Michael Daum: Fixed CC emails; fixed css in docu | 
		
			| 17 Oct 2008 | 1.21 Michael Daum: Added support for TWiki-5; fixed sending emails to login names | 
		
			| 26 Jun 2008 | 1.20 Michael Daum:                  Added ALLOW/DENY preference settings to prevent this plugin from being used as an open spam relay;                  added templateoption allowing more control over email header etc;                  fixed mod_perl/perperl coding errors;                 sender address is the current user, it will default to the wikimaster's only as a last resort;                  allow user names in addition to plain email addresses in From, To and Cc;                  allow multiple users in To and Cc;                  added aredirectto,successsectionanderrorsectionoptions to land on a different feedback page;                  reorganized code for lazy compilation | 
		
			| 16 may 2007 | 1.13 Arthur Clemens: Fixed bug in bin script that caused form query data to get emptied. | 
		
			| 15 may 2007 | 1.12 Arthur Clemens: Improved error notifications. | 
		
			| 13 May 2007 | 1.11 Arthur Clemens: Changed sendmail script invocation to be called through bin script sendemail; added CSS styles for feedback notification; fixed typo 'feedbackSucces'. | 
		
			| 05 May 2007 | 1.0 First release. |