This commit is contained in:
2024-10-14 00:08:40 +02:00
parent dbfba56f66
commit 1462d52e13
4572 changed files with 2658864 additions and 0 deletions

View File

@@ -0,0 +1,106 @@
# --
# Copyright (C) 2001-2019 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( Limit => 400 ) || '';
# Split data to lines.
my @Message = split /\n/, $Log;
# 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 (@Message) {
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 ( !@Message ) {
$LayoutObject->Block(
Name => 'AdminLogNoDataRow',
Data => {},
);
}
# Create & return output.
$Output .= $LayoutObject->Output(
TemplateFile => 'AdminLog',
Data => \%Param,
);
$Output .= $LayoutObject->Footer();
return $Output;
}
1;