Email notify-on-fave moved to Profile_prefs (run upgrade.php)

This commit is contained in:
Mikael Nordfeldth 2014-07-13 17:13:05 +02:00
parent b46b588522
commit 0a20abf1d8
7 changed files with 73 additions and 27 deletions

View File

@ -214,13 +214,6 @@ class EmailsettingsAction extends SettingsAction
$user->emailnotifysub); $user->emailnotifysub);
$this->elementEnd('li'); $this->elementEnd('li');
$this->elementStart('li'); $this->elementStart('li');
$this->checkbox('emailnotifyfav',
// TRANS: Checkbox label in e-mail preferences form.
_('Send me email when someone '.
'adds my notice as a favorite.'),
$user->emailnotifyfav);
$this->elementEnd('li');
$this->elementStart('li');
$this->checkbox('emailnotifymsg', $this->checkbox('emailnotifymsg',
// TRANS: Checkbox label in e-mail preferences form. // TRANS: Checkbox label in e-mail preferences form.
_('Send me email when someone sends me a private message.'), _('Send me email when someone sends me a private message.'),
@ -324,7 +317,6 @@ class EmailsettingsAction extends SettingsAction
if (Event::handle('StartEmailSaveForm', array($this, $this->scoped))) { if (Event::handle('StartEmailSaveForm', array($this, $this->scoped))) {
$emailnotifysub = $this->boolean('emailnotifysub'); $emailnotifysub = $this->boolean('emailnotifysub');
$emailnotifyfav = $this->boolean('emailnotifyfav');
$emailnotifymsg = $this->boolean('emailnotifymsg'); $emailnotifymsg = $this->boolean('emailnotifymsg');
$emailnotifynudge = $this->boolean('emailnotifynudge'); $emailnotifynudge = $this->boolean('emailnotifynudge');
$emailnotifyattn = $this->boolean('emailnotifyattn'); $emailnotifyattn = $this->boolean('emailnotifyattn');
@ -338,7 +330,6 @@ class EmailsettingsAction extends SettingsAction
$original = clone($user); $original = clone($user);
$user->emailnotifysub = $emailnotifysub; $user->emailnotifysub = $emailnotifysub;
$user->emailnotifyfav = $emailnotifyfav;
$user->emailnotifymsg = $emailnotifymsg; $user->emailnotifymsg = $emailnotifymsg;
$user->emailnotifynudge = $emailnotifynudge; $user->emailnotifynudge = $emailnotifynudge;
$user->emailnotifyattn = $emailnotifyattn; $user->emailnotifyattn = $emailnotifyattn;

View File

@ -73,7 +73,7 @@ class User extends Managed_DataObject
'email' => array('type' => 'varchar', 'length' => 255, 'description' => 'email address for password recovery etc.'), 'email' => array('type' => 'varchar', 'length' => 255, 'description' => 'email address for password recovery etc.'),
'incomingemail' => array('type' => 'varchar', 'length' => 255, 'description' => 'email address for post-by-email'), 'incomingemail' => array('type' => 'varchar', 'length' => 255, 'description' => 'email address for post-by-email'),
'emailnotifysub' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of subscriptions'), 'emailnotifysub' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of subscriptions'),
'emailnotifyfav' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of favorites'), 'emailnotifyfav' => array('type' => 'int', 'size' => 'tiny', 'default' => null, 'description' => 'Notify by email of favorites'),
'emailnotifynudge' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of nudges'), 'emailnotifynudge' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of nudges'),
'emailnotifymsg' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of direct messages'), 'emailnotifymsg' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of direct messages'),
'emailnotifyattn' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of @-replies'), 'emailnotifyattn' => array('type' => 'int', 'size' => 'tiny', 'default' => 1, 'description' => 'Notify by email of @-replies'),
@ -289,7 +289,6 @@ class User extends Managed_DataObject
// initially for sites using caching, since the initial encache // initially for sites using caching, since the initial encache
// doesn't know about the defaults in the database. // doesn't know about the defaults in the database.
$user->emailnotifysub = 1; $user->emailnotifysub = 1;
$user->emailnotifyfav = 1;
$user->emailnotifynudge = 1; $user->emailnotifynudge = 1;
$user->emailnotifymsg = 1; $user->emailnotifymsg = 1;
$user->emailnotifyattn = 1; $user->emailnotifyattn = 1;

View File

@ -683,6 +683,10 @@ function mail_notify_fave(User $rcpt, Profile $sender, Notice $notice)
return; return;
} }
if (!$rcpt->getPref('notify', 'email_fave', 1)) {
return;
}
$bestname = $profile->getBestName(); $bestname = $profile->getBestName();
common_switch_locale($rcpt->language); common_switch_locale($rcpt->language);

View File

@ -25,6 +25,8 @@ if (!defined('GNUSOCIAL')) { exit(1); }
*/ */
class FavoritePlugin extends ActivityHandlerPlugin class FavoritePlugin extends ActivityHandlerPlugin
{ {
protected $notify_email_fave = 1;
public function tag() public function tag()
{ {
return 'favorite'; return 'favorite';
@ -46,6 +48,27 @@ class FavoritePlugin extends ActivityHandlerPlugin
$schema->ensureTable('fave', Fave::schemaDef()); $schema->ensureTable('fave', Fave::schemaDef());
return true; return true;
} }
public function onStartUpgrade()
{
// This is a migration feature that will make sure we move
// certain User preferences to the Profile_prefs table.
// Introduced after commit b5fd2a048fc621ea05d756caba17275ab3dd0af4
// on Sun Jul 13 16:30:37 2014 +0200
$user = new User();
$user->whereAdd('emailnotifyfav IS NOT NULL');
if ($user->find()) {
printfnq("Detected old User table (emailnotifyfav IS NOT NULL). Moving 'emailnotifyfav' property to Profile_prefs...");
// Make sure we have our own tables setup properly
while ($user->fetch()) {
$user->setPref('email', 'notify_fave', $user->emailnotifyfav);
$orig = clone($user);
$user->emailnotifyfav = 'null'; // flag this preference as migrated
$user->update($orig);
}
printfnq("DONE.\n");
}
}
public function onEndUpgrade() public function onEndUpgrade()
{ {
@ -198,7 +221,7 @@ class FavoritePlugin extends ActivityHandlerPlugin
foreach ($mentioned_ids as $id) { foreach ($mentioned_ids as $id) {
$mentioned = User::getKV('id', $id); $mentioned = User::getKV('id', $id);
if ($mentioned instanceof User && $mentioned->id != $stored->profile_id if ($mentioned instanceof User && $mentioned->id != $stored->profile_id
&& $mentioned->email && $mentioned->emailnotifyfav) { // do we have an email, and does user want it? && $mentioned->email && $mentioned->getPref('email', 'notify_fave', $this->notify_email_fave)) { // do we have an email, and does user want it?
mail_notify_fave($mentioned, $stored->getProfile(), $stored->getParent()); mail_notify_fave($mentioned, $stored->getProfile(), $stored->getParent());
} }
} }
@ -390,6 +413,41 @@ class FavoritePlugin extends ActivityHandlerPlugin
$supported = $supported || $cmd instanceof FavCommand; $supported = $supported || $cmd instanceof FavCommand;
} }
// Form stuff (settings etc.)
public function onEndEmailFormData(Action $action, Profile $scoped)
{
// getConfigData will fall back on systemwide default
// and we only wish to save numerical true or false.
$emailfave = $scoped->getPref('email', 'notify_fave', $this->notify_email_fave) ? 1 : 0;
$action->elementStart('li');
$action->checkbox('email-notify_fave',
// TRANS: Checkbox label in e-mail preferences form.
_('Send me email when someone adds my notice as a favorite.'),
$emailfave);
$action->elementEnd('li');
return true;
}
public function onStartEmailSaveForm(Action $action, Profile $scoped)
{
$emailfave = $action->boolean('email-notify_fave') ? 1 : 0;
try {
if ($emailfave == $scoped->getPref('email', 'notify_fave')) {
// No need to update setting
return true;
}
} catch (NoResultException $e) {
// Apparently there's no previously stored setting, then continue to save it as it is now.
}
$scoped->setPref('email', 'notify_fave', $emailfave);
return true;
}
// Layout stuff // Layout stuff
public function onEndPersonalGroupNav(Menu $menu, Profile $target, Profile $scoped=null) public function onEndPersonalGroupNav(Menu $menu, Profile $target, Profile $scoped=null)

View File

@ -162,12 +162,10 @@ class ApiFavoriteCreateAction extends ApiAuthAction
function notify($fave, $notice, $user) function notify($fave, $notice, $user)
{ {
$other = User::getKV('id', $notice->profile_id); $other = User::getKV('id', $notice->profile_id);
if ($other && $other->id != $user->id) { if ($other && $other->id != $user->id && !empty($other->email)) {
if ($other->email && $other->emailnotifyfav) { require_once INSTALLDIR.'/lib/mail.php';
require_once INSTALLDIR.'/lib/mail.php';
mail_notify_fave($other, $user->getProfile(), $notice); mail_notify_fave($other, $user->getProfile(), $notice);
}
// XXX: notify by IM // XXX: notify by IM
// XXX: notify by SMS // XXX: notify by SMS
} }

View File

@ -361,12 +361,10 @@ class AtompubfavoritefeedAction extends ApiAuthAction
function notify($fave, $notice, $user) function notify($fave, $notice, $user)
{ {
$other = User::getKV('id', $notice->profile_id); $other = User::getKV('id', $notice->profile_id);
if ($other && $other->id != $user->id) { if ($other && $other->id != $user->id && !empty($other->email)) {
if ($other->email && $other->emailnotifyfav) { require_once INSTALLDIR.'/lib/mail.php';
require_once INSTALLDIR.'/lib/mail.php';
mail_notify_fave($other, $user->getProfile(), $notice); mail_notify_fave($other, $user->getProfile(), $notice);
}
// XXX: notify by IM // XXX: notify by IM
// XXX: notify by SMS // XXX: notify by SMS
} }

View File

@ -38,12 +38,10 @@ class FavCommand extends Command
$other = User::getKV('id', $notice->profile_id); $other = User::getKV('id', $notice->profile_id);
if ($other && $other->id != $this->user->id) { if ($other && $other->id != $this->user->id && !empty($other->email)) {
if ($other->email && $other->emailnotifyfav) { require_once INSTALLDIR.'/lib/mail.php';
require_once INSTALLDIR.'/lib/mail.php';
mail_notify_fave($other, $this->user->getProfile(), $notice); mail_notify_fave($other, $this->user->getProfile(), $notice);
}
} }
Fave::blowCacheForProfileId($this->user->id); Fave::blowCacheForProfileId($this->user->id);