1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
|
# --
# Copyright (C) 2001-2021 OTRS AG, https://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (GPL). If you
# did not receive this file, see https://www.gnu.org/licenses/gpl-3.0.txt.
# --
package Kernel::System::Console::Command::Maint::PostMaster::SpoolMailsReprocess;
use strict;
use warnings;
use parent qw(Kernel::System::Console::BaseCommand);
our @ObjectDependencies = (
'Kernel::Config',
'Kernel::System::Log',
'Kernel::System::Main',
);
sub Configure {
my ( $Self, %Param ) = @_;
$Self->Description('Reprocess mails from spool directory that could not be imported in the first place.');
return;
}
sub PreRun {
my ( $Self, %Param ) = @_;
my $SpoolDir = $Kernel::OM->Get('Kernel::Config')->Get('Home') . '/var/spool';
if ( !-d $SpoolDir ) {
die "Spool directory $SpoolDir does not exist!\n";
}
return;
}
sub Run {
my ( $Self, %Param ) = @_;
my $Home = $Kernel::OM->Get('Kernel::Config')->Get('Home');
my $SpoolDir = "$Home/var/spool";
$Self->Print("<yellow>Processing mails in $SpoolDir...</yellow>\n");
my @Files = $Kernel::OM->Get('Kernel::System::Main')->DirectoryRead(
Directory => $SpoolDir,
Filter => '*',
);
my $Success = 1;
for my $File (@Files) {
$Self->Print(" Processing <yellow>$File</yellow>... ");
# Here we use a system call because Maint::PostMaster::Read has special exception handling
# and will die if certain problems occur.
my $Result = system("$^X $Home/bin/otrs.Console.pl Maint::PostMaster::Read < $File ");
# Exit code 0 == success
if ( !$Result ) {
$Kernel::OM->Get('Kernel::System::Log')->Log(
Priority => 'info',
Message => "Successfully reprocessed email $File.",
);
unlink $File;
$Self->Print("<green>Ok.</green>\n");
}
else {
$Kernel::OM->Get('Kernel::System::Log')->Log(
Priority => 'error',
Message => "Could not re-process email $File.",
);
$Self->Print("<red>Failed.</red>\n");
$Success = 0;
}
}
if ( !$Success ) {
$Self->PrintError("There were problems importing the spool mails.");
return $Self->ExitCodeError();
}
$Self->Print("<green>Done.</green>\n");
return $Self->ExitCodeOk();
}
1;
|