mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-01 03:02:43 +01:00
e80c59cbc6
Summary: Fixes T2458. Ref T2843. @tido's email from T2843 has exhausted its retries and failed, but we want to try it again with the patch from D5464 to capture the actual error. This sort of thing has come up a few times in debugging, too. Also fixed some stuff that came up while debugging this. Test Plan: - Ran command with no args. - Ran resend with no args. - Ran resend with bad IDs. - Ran resend with already-queued messages, got "already queued" error. - Ran resend with already-sent message, got requeue. Reviewers: btrahan, tido Reviewed By: tido CC: aran Maniphest Tasks: T2458, T2843 Differential Revision: https://secure.phabricator.com/D5493
75 lines
1.9 KiB
PHP
75 lines
1.9 KiB
PHP
<?php
|
|
|
|
final class PhabricatorMailManagementResendWorkflow
|
|
extends PhabricatorSearchManagementWorkflow {
|
|
|
|
protected function didConstruct() {
|
|
$this
|
|
->setName('resend')
|
|
->setSynopsis('Send mail again.')
|
|
->setExamples(
|
|
"**resend** --id 1 --id 2")
|
|
->setArguments(
|
|
array(
|
|
array(
|
|
'name' => 'id',
|
|
'param' => 'id',
|
|
'help' => 'Send mail with a given ID again.',
|
|
'repeat' => true,
|
|
),
|
|
));
|
|
}
|
|
|
|
public function execute(PhutilArgumentParser $args) {
|
|
$console = PhutilConsole::getConsole();
|
|
|
|
$ids = $args->getArg('id');
|
|
if (!$ids) {
|
|
throw new PhutilArgumentUsageException(
|
|
"Use the '--id' flag to specify one or more messages to resend.");
|
|
}
|
|
|
|
$messages = id(new PhabricatorMetaMTAMail())->loadAllWhere(
|
|
'id IN (%Ld)',
|
|
$ids);
|
|
|
|
if ($ids) {
|
|
$ids = array_fuse($ids);
|
|
$missing = array_diff_key($ids, $messages);
|
|
if ($missing) {
|
|
throw new PhutilArgumentUsageException(
|
|
"Some specified messages do not exist: ".
|
|
implode(', ', array_keys($missing)));
|
|
}
|
|
}
|
|
|
|
foreach ($messages as $message) {
|
|
if ($message->getStatus() == PhabricatorMetaMTAMail::STATUS_QUEUE) {
|
|
if ($message->getWorkerTaskID()) {
|
|
$console->writeOut(
|
|
"Message #%d is already queued with an assigned send task.\n",
|
|
$message->getID());
|
|
continue;
|
|
}
|
|
}
|
|
|
|
$message->setStatus(PhabricatorMetaMTAMail::STATUS_QUEUE);
|
|
$message->setRetryCount(0);
|
|
$message->setNextRetry(time());
|
|
|
|
$message->save();
|
|
|
|
$mailer_task = PhabricatorWorker::scheduleTask(
|
|
'PhabricatorMetaMTAWorker',
|
|
$message->getID());
|
|
|
|
$message->setWorkerTaskID($mailer_task->getID());
|
|
$message->save();
|
|
|
|
$console->writeOut(
|
|
"Queued message #%d for resend.\n",
|
|
$message->getID());
|
|
}
|
|
}
|
|
|
|
}
|