165 lines
4.4 KiB
Perl
165 lines
4.4 KiB
Perl
# --
|
|
# 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::Output::HTML::Preferences::PGP;
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
our @ObjectDependencies = (
|
|
'Kernel::Config',
|
|
'Kernel::System::Crypt::PGP',
|
|
'Kernel::System::Web::Request',
|
|
'Kernel::System::Log',
|
|
);
|
|
|
|
sub new {
|
|
my ( $Type, %Param ) = @_;
|
|
|
|
# allocate new hash for object
|
|
my $Self = {%Param};
|
|
bless( $Self, $Type );
|
|
|
|
for my $Needed (qw( UserID UserObject ConfigItem )) {
|
|
die "Got no $Needed!" if ( !$Self->{$Needed} );
|
|
}
|
|
|
|
return $Self;
|
|
}
|
|
|
|
sub Param {
|
|
my ( $Self, %Param ) = @_;
|
|
|
|
return if !$Kernel::OM->Get('Kernel::Config')->Get('PGP');
|
|
|
|
my @Params = ();
|
|
push(
|
|
@Params,
|
|
{
|
|
%Param,
|
|
Name => $Self->{ConfigItem}->{PrefKey},
|
|
Block => 'Upload',
|
|
Filename => $Param{UserData}->{PGPFilename},
|
|
},
|
|
);
|
|
return @Params;
|
|
}
|
|
|
|
sub Run {
|
|
my ( $Self, %Param ) = @_;
|
|
|
|
my %UploadStuff = $Kernel::OM->Get('Kernel::System::Web::Request')->GetUploadAll(
|
|
Param => 'UserPGPKey',
|
|
);
|
|
return 1 if !$UploadStuff{Content};
|
|
|
|
my $PGPObject = $Kernel::OM->Get('Kernel::System::Crypt::PGP');
|
|
return 1 if !$PGPObject;
|
|
|
|
my $Message = $PGPObject->KeyAdd( Key => $UploadStuff{Content} );
|
|
if ( !$Message ) {
|
|
$Self->{Error} = $Kernel::OM->Get('Kernel::System::Log')->GetLogEntry(
|
|
Type => 'Error',
|
|
What => 'Message',
|
|
);
|
|
return;
|
|
}
|
|
else {
|
|
if ( $Message =~ /gpg: key (.*):/ ) {
|
|
my @Result = $PGPObject->PublicKeySearch( Search => $1 );
|
|
if ( $Result[0] ) {
|
|
$UploadStuff{Filename}
|
|
= "$Result[0]->{Identifier}-$Result[0]->{Bit}-$Result[0]->{Key}.$Result[0]->{Type}";
|
|
}
|
|
}
|
|
|
|
$Self->{UserObject}->SetPreferences(
|
|
UserID => $Param{UserData}->{UserID},
|
|
Key => 'PGPKeyID', # new parameter PGPKeyID
|
|
Value => $1, # write KeyID on a per user base
|
|
);
|
|
$Self->{UserObject}->SetPreferences(
|
|
UserID => $Param{UserData}->{UserID},
|
|
Key => 'PGPFilename',
|
|
Value => $UploadStuff{Filename},
|
|
);
|
|
|
|
# $Self->{UserObject}->SetPreferences(
|
|
# UserID => $Param{UserData}->{UserID},
|
|
# Key => 'UserPGPKey',
|
|
# Value => $UploadStuff{Content},
|
|
# );
|
|
# $Self->{UserObject}->SetPreferences(
|
|
# UserID => $Param{UserData}->{UserID},
|
|
# Key => "PGPContentType",
|
|
# Value => $UploadStuff{ContentType},
|
|
# );
|
|
$Self->{Message} = $Message;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
sub Download {
|
|
my ( $Self, %Param ) = @_;
|
|
|
|
my $PGPObject = $Kernel::OM->Get('Kernel::System::Crypt::PGP');
|
|
return 1 if !$PGPObject;
|
|
|
|
# get preferences with key parameters
|
|
my %Preferences = $Self->{UserObject}->GetPreferences(
|
|
UserID => $Param{UserData}->{UserID},
|
|
);
|
|
|
|
# get log object
|
|
my $LogObject = $Kernel::OM->Get('Kernel::System::Log');
|
|
|
|
# check if PGPKeyID is there
|
|
if ( !$Preferences{PGPKeyID} ) {
|
|
$LogObject->Log(
|
|
Priority => 'Error',
|
|
Message => 'Need KeyID to get pgp public key of ' . $Param{UserData}->{UserID},
|
|
);
|
|
return ();
|
|
}
|
|
else {
|
|
$Preferences{PGPKeyContent} = $PGPObject->PublicKeyGet(
|
|
Key => $Preferences{PGPKeyID},
|
|
);
|
|
}
|
|
|
|
# return content of key
|
|
if ( !$Preferences{PGPKeyContent} ) {
|
|
$LogObject->Log(
|
|
Priority => 'Error',
|
|
Message => 'Couldn\'t get ASCII exported pubKey for KeyID ' . $Preferences{'PGPKeyID'},
|
|
);
|
|
return;
|
|
}
|
|
else {
|
|
return (
|
|
ContentType => 'text/plain',
|
|
Content => $Preferences{PGPKeyContent},
|
|
Filename => $Preferences{PGPFilename} || $Preferences{PGPKeyID} . '_pgp.asc',
|
|
);
|
|
}
|
|
}
|
|
|
|
sub Error {
|
|
my ( $Self, %Param ) = @_;
|
|
|
|
return $Self->{Error} || '';
|
|
}
|
|
|
|
sub Message {
|
|
my ( $Self, %Param ) = @_;
|
|
|
|
return $Self->{Message} || '';
|
|
}
|
|
|
|
1;
|