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 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
# --
# 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::Modules::AdminLog;
use strict;
use warnings;
our $ObjectManagerDisabled = 1;
sub new {
my ( $Type, %Param ) = @_;
# Allocate new hash for object.
my $Self = {%Param};
bless( $Self, $Type );
return $Self;
}
sub Run {
my ( $Self, %Param ) = @_;
my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');
# Print form.
my $Output = $LayoutObject->Header();
$Output .= $LayoutObject->NavigationBar();
# Get log data.
my $Log = $Kernel::OM->Get('Kernel::System::Log')->GetLog() || '';
# Split data to lines.
my $Limit = 400;
my @Messages = split /\n/, $Log;
splice @Messages, $Limit;
# Create months map.
my %MonthMap;
my @Months = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec);
@MonthMap{@Months} = ( 1 .. 12 );
# Get current user time zone.
my $TimeZone = $Self->{UserTimeZone} || $Kernel::OM->Create('Kernel::System::DateTime')->UserDefaultTimeZoneGet();
# Create table.
ROW:
for my $Row (@Messages) {
my @Parts = split /;;/, $Row;
next ROW if !$Parts[3];
my $ErrorClass = ( $Parts[1] =~ /error/ ) ? 'Error' : '';
# Create date and time object from ctime log stamp.
my @Time = split ' ', $Parts[0];
my $DateTimeObject = $Kernel::OM->Create(
'Kernel::System::DateTime',
ObjectParams => {
String => "$Time[4]-$MonthMap{$Time[1]}-$Time[2] $Time[3]",
},
);
# Converts the date and time of this object to the user time zone.
$DateTimeObject->ToTimeZone(
TimeZone => $TimeZone,
);
# Output time back as ctime string with time zone.
$Parts[0] = $DateTimeObject->ToCTimeString() . " ($TimeZone)";
$LayoutObject->Block(
Name => 'Row',
Data => {
ErrorClass => $ErrorClass,
Time => $Parts[0],
Priority => $Parts[1],
Facility => $Parts[2],
Message => $Parts[3],
},
);
}
# Print no data found message.
if ( !@Messages ) {
$LayoutObject->Block(
Name => 'AdminLogNoDataRow',
Data => {},
);
}
# Create & return output.
$Output .= $LayoutObject->Output(
TemplateFile => 'AdminLog',
Data => \%Param,
);
$Output .= $LayoutObject->Footer();
return $Output;
}
1;
|