2006-07-11 21:56:53 +00:00
|
|
|
<?php
|
|
|
|
require_once("docutil.php");
|
2006-07-28 16:09:10 +00:00
|
|
|
page_head("Email tools: newsletters, reminders, and friend-to-friend");
|
2006-07-11 21:56:53 +00:00
|
|
|
echo "
|
2006-07-28 16:09:10 +00:00
|
|
|
BOINC provides PHP-based tools
|
|
|
|
for sending three types of email to participants:
|
2006-07-13 23:40:10 +00:00
|
|
|
<ul>
|
|
|
|
<li> <b>Newsletters</b>.
|
|
|
|
These are periodic (perhaps every few months) and are sent to all participants.
|
|
|
|
Typically you would use them to summarize your project's results,
|
|
|
|
to discuss its future plans, to make announcements, etc.
|
|
|
|
<li> <b>Reminders</b>.
|
|
|
|
These are sent to participants who seem to have stopped
|
|
|
|
computing to your project, or who signed up but never got any credit.
|
|
|
|
Typically they would be short messages,
|
|
|
|
encouraging the participant to take a specific action.
|
2006-07-28 16:09:10 +00:00
|
|
|
<li> <b>Friend-to-friend</b>.
|
|
|
|
These are sent by participants to their friends and family,
|
|
|
|
to tell them about your project and urge them to join.
|
|
|
|
<b>You must write this email</b>.
|
|
|
|
The sender can add an optional message.
|
2006-07-13 23:40:10 +00:00
|
|
|
</ul>
|
2006-07-28 16:09:10 +00:00
|
|
|
Effective use of all types of email
|
2006-07-13 23:40:10 +00:00
|
|
|
is critical to maintaining and growing your participant base.
|
2006-07-28 16:09:10 +00:00
|
|
|
In the absence of any email,
|
|
|
|
participation typically decreases by a few percent every month.
|
2006-07-13 23:40:10 +00:00
|
|
|
<p>
|
2006-07-28 16:09:10 +00:00
|
|
|
The newsletter and reminder scripts provide the following features:
|
2006-07-13 23:40:10 +00:00
|
|
|
<ul>
|
|
|
|
<li> They let you send different emails to different 'classes' of participants.
|
|
|
|
For example, you can send a different newsletter
|
|
|
|
to participants who haven't computed for your project in a while.
|
|
|
|
<li> They let you personalize emails,
|
|
|
|
e.g. by inserting the participant's name or their total credit.
|
|
|
|
<li> They provide a mechanism for inserting a
|
|
|
|
secure 'opt-out' link.
|
|
|
|
Note: You should ALWAYS include an 'opt-out' link
|
|
|
|
at the bottom of emails (both HTML and text).
|
|
|
|
In may be illegal for you to do a mass email without one.
|
|
|
|
Make sure you test this link.
|
|
|
|
</ul>
|
|
|
|
<p>
|
|
|
|
The scripts requires that you use
|
|
|
|
<a href=http://phpmailer.sourceforge.net/>PHPMailer</a>,
|
2006-07-11 21:56:53 +00:00
|
|
|
is a PHP function for sending mail that's more full-featured
|
|
|
|
than the one built into PHP.
|
2006-07-13 23:40:10 +00:00
|
|
|
Download it, put it in html/inc, and set the
|
|
|
|
USE_PHPMAILER, PHPMAILER_HOST, and PHPMAILER_MAILER variables in
|
2006-07-11 21:56:53 +00:00
|
|
|
<a href=http://boinc.berkeley.edu/web_config.php>your project.inc file</a>.
|
2006-07-28 16:09:10 +00:00
|
|
|
<p>
|
|
|
|
All of the tools let you send multipart HTML/text messages.
|
|
|
|
We recommend that you use this feature -
|
|
|
|
and HTML message can include your logo and/or institutional insignia,
|
|
|
|
can include hyperlinks,
|
|
|
|
and can look more attractive.
|
2006-07-13 23:40:10 +00:00
|
|
|
|
2006-07-11 21:56:53 +00:00
|
|
|
<p>
|
2006-07-13 23:40:10 +00:00
|
|
|
The general procedure for using each scripts is:
|
|
|
|
<ul>
|
2006-07-28 16:09:10 +00:00
|
|
|
<li> Create a directory (mass_email, reminder_email, or ffmail)
|
2006-07-13 23:40:10 +00:00
|
|
|
in your html/ops/ directory.
|
|
|
|
In that directory, create separate files for
|
|
|
|
the text body template, HTML body template, and subject line
|
|
|
|
to be sent to each class of participants.
|
|
|
|
NOTE: the HTML files are optional;
|
|
|
|
if you leave them out, text-only emails will be sent.
|
|
|
|
<li>
|
|
|
|
Run the script in testing mode (see below)
|
|
|
|
to ensure that the emails are as you intend.
|
|
|
|
<li>
|
|
|
|
Once testing is complete, run the script in production mode.
|
|
|
|
Typically, the newsletter script is run from the command line.
|
|
|
|
The reminder script is typically run as a
|
|
|
|
<a href=tasks.php>periodic task</a>, every 24 hours or so.
|
|
|
|
</ul>
|
|
|
|
|
2006-07-28 16:09:10 +00:00
|
|
|
The newsletter and reminder scripts use the recent-average credit
|
|
|
|
(expavg_credit) field in the user table.
|
2006-07-13 23:40:10 +00:00
|
|
|
To make sure this value is accurate,
|
2006-07-17 16:38:53 +00:00
|
|
|
run <a href=project_tasks.php>update_stats</a> manually
|
2006-07-13 23:40:10 +00:00
|
|
|
if you're not running it as a periodic task.
|
|
|
|
|
|
|
|
<h3>Personalizing emails</h3>
|
|
|
|
<p>
|
2006-07-28 16:09:10 +00:00
|
|
|
The newsletter and reminder scripts
|
|
|
|
replace the following macros in your email bodies
|
2006-07-13 23:40:10 +00:00
|
|
|
(both HTML and text):
|
|
|
|
";
|
|
|
|
list_start();
|
|
|
|
list_item("<name/>", "User name");
|
|
|
|
list_item("<create_time/>", "When account was created (D M Y)");
|
|
|
|
list_item("<total_credit/>", "User's total credit");
|
|
|
|
list_item("<opt_out_url/>",
|
|
|
|
"URL for opting out (this URL includes a salted version
|
|
|
|
of the participant's account key, and so is different for every participant).
|
|
|
|
");
|
2006-07-20 20:27:21 +00:00
|
|
|
list_item("<lapsed_interval/>",
|
|
|
|
"The number of days since user's client contacted server
|
|
|
|
(defined only for lapsed users, see below)."
|
|
|
|
);
|
|
|
|
list_item("<user_id/>",
|
|
|
|
"The user ID (use this to form URLs)"
|
|
|
|
);
|
2006-07-13 23:40:10 +00:00
|
|
|
list_end();
|
|
|
|
|
|
|
|
echo "
|
|
|
|
<p>
|
|
|
|
|
|
|
|
<h3>Avoiding spam filtering</h3>
|
|
|
|
Your email is less likely to be rejected by spam filters if:
|
|
|
|
<ul>
|
|
|
|
<li> Your HTML and text versions have the same text.
|
|
|
|
<li> Your HTML version either contains no images,
|
|
|
|
or has at least 400 words.
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<h2>Newsletters</h2>
|
|
|
|
<p>
|
|
|
|
The script <b>html/ops/mass_email_script.php</b>
|
|
|
|
is for sending email newsletters.
|
|
|
|
The script categorize participants as follows:
|
2006-07-11 21:56:53 +00:00
|
|
|
<ul>
|
|
|
|
<li> <b>Failed</b>: zero total credit.
|
|
|
|
These people failed to download and install the client software,
|
|
|
|
or failed to get it working (e.g. because of proxy problems)
|
|
|
|
or uninstalled it before finishing any work.
|
|
|
|
<li> <b>Lapsed</b>: nonzero total credit but recent average credit < 1:
|
|
|
|
These people did work in the past, but none recently.
|
|
|
|
<li> <b>Current</b>: recent average credit >= 1.
|
2006-07-13 23:40:10 +00:00
|
|
|
These are your active participants.
|
2006-07-11 21:56:53 +00:00
|
|
|
</ul>
|
|
|
|
|
2006-07-13 23:40:10 +00:00
|
|
|
To use the script, create the following files in html/ops/mass_email:
|
2006-07-11 21:56:53 +00:00
|
|
|
";
|
|
|
|
list_start();
|
2006-07-13 16:48:44 +00:00
|
|
|
list_item("failed_html",
|
2006-07-11 21:56:53 +00:00
|
|
|
"HTML message sent to failed users. Example: ".html_text(
|
|
|
|
"<html>
|
|
|
|
<body bgcolor=ffffcc>
|
|
|
|
Dear <name/>:
|
|
|
|
<p>
|
|
|
|
Test Project continues to do pioneering computational research
|
|
|
|
in the field of Submandibular Morphology.
|
2006-07-13 16:48:44 +00:00
|
|
|
In recent months we have discovered over 17 new varieties of Frombats.
|
2006-07-11 21:56:53 +00:00
|
|
|
<p>
|
|
|
|
Our records show that you created a Test Project account
|
|
|
|
on <create_time/> but that your computer hasn't completed any work.
|
2006-07-13 23:40:10 +00:00
|
|
|
Possibly you encountered problems installing or using the software.
|
2006-07-11 21:56:53 +00:00
|
|
|
Many of these problems have now been fixed,
|
|
|
|
and we encourage you to visit
|
|
|
|
<a href=http://a.b.c>our web site</a>,
|
|
|
|
download the latest version of the software, and try again.
|
|
|
|
<p>
|
|
|
|
<font size=-2>
|
2006-07-13 23:40:10 +00:00
|
|
|
To not receive future emails from Test Project,
|
2006-07-11 21:56:53 +00:00
|
|
|
<a href=<opt_out_url/>>click here</a>.
|
|
|
|
</font>
|
|
|
|
</td></tr></table>
|
|
|
|
</body>
|
|
|
|
</html>"
|
|
|
|
)."
|
|
|
|
");
|
2006-07-13 16:48:44 +00:00
|
|
|
list_item("failed_text", "Text message sent to failed users.
|
2006-07-11 21:56:53 +00:00
|
|
|
Example: ".html_text("
|
|
|
|
Dear <name/>:
|
|
|
|
|
|
|
|
Test Project continues to do pioneering computational research
|
|
|
|
in the field of Submandibular Morphology.
|
|
|
|
In recent months we have discovered over 17 new varieties of Frombats.
|
|
|
|
|
|
|
|
Our records show that you created a Test Project account
|
|
|
|
on <create_time/> but that your computer hasn't completed any work.
|
|
|
|
Quite possibly you encountered problems installing or using the software.
|
|
|
|
Many of these problems have now been fixed,
|
|
|
|
and we encourage you to visit <a href=http://a.b.c>our web site</a>,
|
|
|
|
download the latest version of the software, and try again.
|
|
|
|
|
2006-07-13 23:40:10 +00:00
|
|
|
To not receive future emails from Test Project, visit
|
2006-07-11 21:56:53 +00:00
|
|
|
<opt_out_url/>"
|
|
|
|
)."
|
|
|
|
");
|
|
|
|
list_item("email_failed_subject", "Subject line sent to failed users.
|
|
|
|
Example: 'Test Project News'.
|
|
|
|
");
|
2006-07-13 16:48:44 +00:00
|
|
|
list_item("lapsed_html", "HTML message sent to lapsed users");
|
|
|
|
list_item("lapsed_text", "Text message sent to lapsed users");
|
|
|
|
list_item("lapsed_subject", "Subject line sent to lapsed users");
|
|
|
|
list_item("current_html", "HTML message sent to current users");
|
|
|
|
list_item("current_text", "Text message sent to current users");
|
|
|
|
list_item("current_subject", "Subject line sent to current users");
|
2006-07-11 21:56:53 +00:00
|
|
|
list_end();
|
|
|
|
echo "
|
2006-07-13 23:40:10 +00:00
|
|
|
<h3>Testing</h3>
|
2006-07-11 21:56:53 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
Test your email before sending it out to the world.
|
|
|
|
As distributed, mass_email_script.php has the following
|
|
|
|
variables defined near the top:
|
|
|
|
<pre>
|
|
|
|
\$testing = true;
|
2006-07-13 23:40:10 +00:00
|
|
|
</pre>
|
|
|
|
Set it to false to actually send emails (rather than just print to stdout).
|
|
|
|
<pre>
|
2006-07-11 21:56:53 +00:00
|
|
|
\$userid = 1;
|
|
|
|
</pre>
|
2006-07-13 23:40:10 +00:00
|
|
|
If this is nonzero, email will be sent to the given user ID;
|
|
|
|
Otherwise it will be sent to all users.
|
|
|
|
<p>
|
2006-07-11 21:56:53 +00:00
|
|
|
To start, set \$userid to the ID of your own user record.
|
|
|
|
Run the script by typing
|
|
|
|
<pre>
|
|
|
|
php mass_email_script.php
|
|
|
|
</pre>
|
|
|
|
It will print (to stdout) the contents of all three email types
|
|
|
|
(failed, lapsed, and current).
|
2006-07-13 23:40:10 +00:00
|
|
|
Verify that the subject, HTML and text are correct.
|
2006-07-11 21:56:53 +00:00
|
|
|
<p>
|
|
|
|
Then set \$testing = false and run the script again.
|
|
|
|
You'll get three emails; check them.
|
|
|
|
<p>
|
|
|
|
Then set \$testing = false and \$userid = 0,
|
2006-07-13 16:48:44 +00:00
|
|
|
create an empty file called <b>mass_email/log</b> (see below),
|
2006-07-11 21:56:53 +00:00
|
|
|
and run the script.
|
|
|
|
You'll get voluminous output to stdout, but no emails will be sent.
|
|
|
|
Control-C it quickly if you want.
|
|
|
|
Make sure that each user is being sent the right type of email.
|
|
|
|
<p>
|
|
|
|
When you're sure that everything is correct,
|
|
|
|
set \$testing = false,
|
2006-07-13 16:48:44 +00:00
|
|
|
set <b>mass_email/log</b> to empty,
|
2006-07-11 21:56:53 +00:00
|
|
|
and run the script.
|
|
|
|
It will now send mass emails.
|
|
|
|
Depending on the size of your user table,
|
|
|
|
it may take hours or days to complete.
|
|
|
|
You can control-C it and restart whenever you want;
|
|
|
|
it automatically picks up where it left off (see below).
|
|
|
|
|
2006-07-13 23:40:10 +00:00
|
|
|
<h3>Checkpoint/restart</h3>
|
2006-07-11 21:56:53 +00:00
|
|
|
<p>
|
2006-07-13 23:40:10 +00:00
|
|
|
<b>mass_email_script.php</b>
|
|
|
|
manages checkpoint/restart when dealing with large numbers of participants.
|
2006-07-11 21:56:53 +00:00
|
|
|
Mails are sent in order of increasing user ID.
|
2006-07-13 16:48:44 +00:00
|
|
|
The file <b>mass_email/log</b> has a list of IDs that have been processed.
|
2006-07-11 21:56:53 +00:00
|
|
|
On startup, the script reads this file, finds the last entry,
|
|
|
|
and starts from there.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
If you are starting a mass email from the beginning,
|
2006-07-13 16:48:44 +00:00
|
|
|
empty the file <b>mass_email/log</b>; i.e.
|
2006-07-11 21:56:53 +00:00
|
|
|
<pre>
|
2006-07-13 16:48:44 +00:00
|
|
|
truncate mass_email/log
|
2006-07-11 21:56:53 +00:00
|
|
|
</pre>
|
|
|
|
|
2006-07-13 23:40:10 +00:00
|
|
|
<h2>Reminder emails</h2>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The script <b>html/ops/remind.php</b> is for sending reminder emails.
|
|
|
|
The script categorizes users as follows.
|
2006-07-11 21:56:53 +00:00
|
|
|
<ul>
|
2006-07-13 23:40:10 +00:00
|
|
|
<li> <b>Failed</b>: the account was created at least 14 days ago,
|
|
|
|
has zero total credit,
|
|
|
|
and hasn't received a reminder email in 30 days.
|
|
|
|
These people typically either had a technical glitch,
|
|
|
|
or their hardware and/or preferences didn't allow sending them work,
|
|
|
|
or the application crashed on their host.
|
|
|
|
The reminder email should direct them to a web page
|
|
|
|
that helps them fix these problems.
|
|
|
|
<li> <b>Lapsed</b>: the user has positive total credit,
|
|
|
|
hasn't done a scheduler RPC in the past 60 days,
|
|
|
|
and hasn't been sent a reminder email in the past 30 days.
|
|
|
|
They probably stopped running BOINC
|
|
|
|
or detached this project.
|
|
|
|
The reminder email should gently prod them to
|
|
|
|
start running BOINC and attach to this project again.
|
|
|
|
</ul>
|
|
|
|
The numbers 14, 30, and 60 are all parameters in the script;
|
|
|
|
edit it to change them.
|
|
|
|
<p>
|
|
|
|
To use the script, create the following files in <b>html/ops/reminder_email</b>:
|
|
|
|
";
|
|
|
|
list_start();
|
|
|
|
list_item("failed_html", "HTML message sent to failed users");
|
|
|
|
list_item("failed_text", "Text message sent to failed users");
|
|
|
|
list_item("failed_subject", "Subject line sent to failed users");
|
|
|
|
list_item("lapsed_html", "HTML message sent to lapsed users");
|
|
|
|
list_item("lapsed_text", "Text message sent to lapsed users");
|
|
|
|
list_item("lapsed_subject", "Subject line sent to lapsed users");
|
|
|
|
list_end();
|
|
|
|
echo "
|
|
|
|
<p>
|
|
|
|
remind.php can be run as often as you like.
|
|
|
|
We recommend running it every hours, specifying it as a task in config.xml.
|
|
|
|
When it sends email to a user, it stores the time in their database record,
|
|
|
|
and won't send them another email for at least 30 days.
|
|
|
|
For this reason, it has no checkpoint/restart mechanism.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The procedure for testing your reminder email is
|
|
|
|
similar to that for email newsletters (see above).
|
2006-07-11 21:56:53 +00:00
|
|
|
|
|
|
|
";
|
|
|
|
page_tail();
|
|
|
|
?>
|