123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- <?php
- /**
- * StatusNet - the distributed open-source microblogging tool
- *
- * Handler for queue items of type 'uinvrem' - sends an email reminder to
- * an email address of someone who has been invited to the site
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- * @category Email
- * @package StatusNet
- * @author Zach Copley <zach@status.net>
- * @copyright 2011 StatusNet, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
- * @link http://status.net/
- */
- if (!defined('STATUSNET')) {
- exit(1);
- }
- /**
- * Handler for queue items of type 'uinvrem' (user invite reminder)
- *
- * @category Email
- * @package StatusNet
- * @author Zach Copley <zach@status.net>
- * @copyright 2011 StatusNet, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
- * @link http://status.net/
- */
- class UserInviteReminderHandler extends UserReminderHandler {
- const INVITE_REMINDER = 'invite';
- /**
- * Return transport keyword which identifies items this queue handler
- * services; must be defined for all subclasses.
- *
- * Must be 8 characters or less to fit in the queue_item database.
- * ex "email", "jabber", "sms", "irc", ...
- *
- * @return string
- */
- function transport() {
- return 'uinvrem';
- }
- /**
- * Send an invitation reminder. We'll send one after one day, and then
- * one after three days.
- *
- * @todo Abstract this stuff further
- *
- * @param array $invitem Invitation obj and any special options
- * @return boolean success value
- */
- function sendNextReminder($invitem)
- {
- list($invitation, $opts) = $invitem;
- $invDate = strtotime($invitation->created);
- $now = strtotime('now');
- // Days since first invitation was sent
- $days = ($now - $invDate) / 86499; // 60*60*24 = 86499
- // $days = ($now - $regDate) / 120; // Two mins, good for testing
- $siteName = common_config('site', 'name');
- if ($days > 7 && isset($opts['onetime'])) {
- // Don't send the reminder if we're past the normal reminder window and
- // we've already pestered her at all before
- if (Email_reminder::needsReminder(self::INVITE_REMINDER, $invitation)) {
- common_log(LOG_INFO, "Sending one-time invitation reminder to {$invitation->address}", __FILE__);
- $subject = _m("Reminder - you have been invited to join {$siteName}!");
- return EmailReminderPlugin::sendReminder(
- self::INVITE_REMINDER,
- $invitation,
- $subject,
- -1 // special one-time indicator
- );
- }
- }
- switch($days) {
- case ($days > 1 && $days < 2):
- if (Email_reminder::needsReminder(self::INVITE_REMINDER, $invitation, 1)) {
- common_log(LOG_INFO, "Sending one day invitation reminder to {$invitation->address}", __FILE__);
- // TRANS: Subject for reminder e-mail. %s is the StatusNet sitename.
- $subject = sprintf(_m('Reminder - You have been invited to join %s!'),$siteName);
- return EmailReminderPlugin::sendReminder(
- self::INVITE_REMINDER,
- $invitation,
- $subject,
- 1);
- } else {
- return true;
- }
- break;
- case ($days > 3 && $days < 4):
- if (Email_reminder::needsReminder(self::INVITE_REMINDER, $invitation, 3)) {
- common_log(LOG_INFO, "Sending three day invitation reminder to {$invitation->address}", __FILE__);
- // TRANS: Subject for reminder e-mail. %s is the StatusNet sitename.
- $subject = sprintf(_m('Final reminder - you have been invited to join %s!'),$siteName);
- return EmailReminderPlugin::sendReminder(
- self::INVITE_REMINDER,
- $invitation,
- $subject,
- 3
- );
- } else {
- return true;
- }
- break;
- default:
- common_log(LOG_INFO, "No need to send invitation reminder to {$invitation->address}.", __FILE__);
- break;
- }
- return true;
- }
- }
|