2016-03-02 14:48:18 +00:00
|
|
|
#!/usr/bin/env php
|
|
|
|
<?php
|
|
|
|
|
2019-07-15 04:10:29 +01:00
|
|
|
define('INSTALLDIR', dirname(__DIR__));
|
|
|
|
define('PUBLICDIR', INSTALLDIR . DIRECTORY_SEPARATOR . 'public');
|
2016-03-02 14:48:18 +00:00
|
|
|
|
|
|
|
$shortoptions = 'e::ay';
|
|
|
|
$longoptions = array('email=', 'all', 'yes');
|
|
|
|
|
|
|
|
$self = basename($_SERVER['PHP_SELF']);
|
|
|
|
|
|
|
|
$helptext = <<<END_OF_HELP
|
|
|
|
{$self} [options]
|
|
|
|
resends confirmation email either for a specific email (if found) or for
|
|
|
|
all lingering confirmations.
|
|
|
|
|
|
|
|
NOTE: You probably want to do something like this to your database first so
|
|
|
|
only relatively fresh accounts get resent this:
|
|
|
|
|
|
|
|
DELETE FROM confirm_address WHERE modified < DATE_SUB(NOW(), INTERVAL 1 month);
|
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
-e --email e-mail address to send for
|
|
|
|
-a --all send for all emails in confirm_address table
|
|
|
|
-y --yes skip interactive verification
|
|
|
|
|
|
|
|
END_OF_HELP;
|
|
|
|
|
|
|
|
require_once INSTALLDIR.'/scripts/commandline.inc';
|
|
|
|
|
|
|
|
$all = false;
|
|
|
|
$ca = null;
|
|
|
|
|
|
|
|
if (have_option('e', 'email')) {
|
|
|
|
$email = get_option_value('e', 'email');
|
2017-04-29 13:48:46 +01:00
|
|
|
try {
|
|
|
|
$ca = Confirm_address::getByAddress($email, 'email');
|
|
|
|
} catch (NoResultException $e) {
|
|
|
|
print sprintf("Can't find %s address %s in %s table.\n", $e->obj->address_type, $e->obj->address, $e->obj->tableName());
|
2016-03-02 14:48:18 +00:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
} elseif (have_option('a', 'all')) {
|
|
|
|
$all = true;
|
|
|
|
$ca = new Confirm_address();
|
|
|
|
$ca->address_type = 'email';
|
|
|
|
if (!$ca->find()) {
|
|
|
|
print "confirm_address table contains no lingering email addresses\n";
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print "You must provide an email (or --all).\n";
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!have_option('y', 'yes')) {
|
|
|
|
print "About to resend confirm_address email to {$ca->N} recipients. Are you sure? [y/N] ";
|
|
|
|
$response = fgets(STDIN);
|
|
|
|
if (strtolower(trim($response)) != 'y') {
|
|
|
|
print "Aborting.\n";
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function mailConfirmAddress(Confirm_address $ca)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$user = User::getByID($ca->user_id);
|
2016-03-06 15:45:29 +00:00
|
|
|
$profile = $user->getProfile();
|
|
|
|
if ($profile->isSilenced()) {
|
|
|
|
$ca->delete();
|
|
|
|
return;
|
|
|
|
}
|
2016-03-02 14:48:18 +00:00
|
|
|
if ($user->email === $ca->address) {
|
|
|
|
throw new AlreadyFulfilledException('User already has identical confirmed email address.');
|
|
|
|
}
|
|
|
|
} catch (AlreadyFulfilledException $e) {
|
|
|
|
print "\n User already had verified email: "._ve($ca->address);
|
|
|
|
$ca->delete();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
print "\n Failed to get user with ID "._ve($user_id).', deleting confirm_address entry: '._ve($e->getMessage());
|
|
|
|
$ca->delete();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
mail_confirm_address($user, $ca->code, $user->getNickname(), $ca->address);
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once(INSTALLDIR . '/lib/mail.php');
|
|
|
|
|
|
|
|
if (!$all) {
|
|
|
|
mailConfirmAddress($ca);
|
|
|
|
} else {
|
|
|
|
while ($ca->fetch()) {
|
|
|
|
mailConfirmAddress($ca);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
print "\nDONE.\n";
|