Linux cpanel.rrshost.in 5.15.0-25-generic #25-Ubuntu SMP Wed Mar 30 15:54:22 UTC 2022 x86_64
Apache
: 109.123.238.221 | : 108.162.241.157
128 Domain
8.2.28
aev999
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
share /
perl5 /
Dpkg /
[ HOME SHELL ]
Name
Size
Permission
Action
Build
[ DIR ]
drwxr-xr-x
Changelog
[ DIR ]
drwxr-xr-x
Compression
[ DIR ]
drwxr-xr-x
Control
[ DIR ]
drwxr-xr-x
Deps
[ DIR ]
drwxr-xr-x
Dist
[ DIR ]
drwxr-xr-x
Interface
[ DIR ]
drwxr-xr-x
Shlibs
[ DIR ]
drwxr-xr-x
Source
[ DIR ]
drwxr-xr-x
Vendor
[ DIR ]
drwxr-xr-x
Arch.pm
14.79
KB
-rw-r--r--
BuildFlags.pm
11.67
KB
-rw-r--r--
BuildOptions.pm
6.18
KB
-rw-r--r--
BuildProfiles.pm
3.88
KB
-rw-r--r--
Changelog.pm
20.19
KB
-rw-r--r--
Checksums.pm
10.97
KB
-rw-r--r--
Compression.pm
6.24
KB
-rw-r--r--
Conf.pm
5.78
KB
-rw-r--r--
Control.pm
7.19
KB
-rw-r--r--
Deps.pm
14.55
KB
-rw-r--r--
ErrorHandling.pm
5.17
KB
-rw-r--r--
Exit.pm
2.43
KB
-rw-r--r--
File.pm
1.25
KB
-rw-r--r--
Getopt.pm
1.21
KB
-rw-r--r--
Gettext.pm
5.64
KB
-rw-r--r--
IPC.pm
11.62
KB
-rw-r--r--
Index.pm
11.31
KB
-rw-r--r--
Lock.pm
1.87
KB
-rw-r--r--
OpenPGP.pm
4.86
KB
-rw-r--r--
Package.pm
1.26
KB
-rw-r--r--
Path.pm
8.6
KB
-rw-r--r--
Shlibs.pm
5.02
KB
-rw-r--r--
Substvars.pm
11.22
KB
-rw-r--r--
Vars.pm
1.42
KB
-rw-r--r--
Vendor.pm
5.34
KB
-rw-r--r--
Version.pm
12.76
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : OpenPGP.pm
# Copyright © 2017 Guillem Jover <guillem@debian.org> # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see <https://www.gnu.org/licenses/>. package Dpkg::OpenPGP; use strict; use warnings; use POSIX qw(:sys_wait_h); use Exporter qw(import); use File::Temp; use File::Copy; use Dpkg::Gettext; use Dpkg::ErrorHandling; use Dpkg::IPC; use Dpkg::Path qw(find_command); our $VERSION = '0.01'; our @EXPORT = qw( openpgp_sig_to_asc ); sub _armor_gpg { my ($sig, $asc) = @_; my @gpg_opts = qw(--no-options); open my $fh_asc, '>', $asc or syserr(g_('cannot create signature file %s'), $asc); open my $fh_gpg, '-|', 'gpg', @gpg_opts, '-o', '-', '--enarmor', $sig or syserr(g_('cannot execute %s program'), 'gpg'); while (my $line = <$fh_gpg>) { next if $line =~ m/^Version: /; next if $line =~ m/^Comment: /; $line =~ s/ARMORED FILE/SIGNATURE/; print { $fh_asc } $line; } close $fh_gpg or subprocerr('gpg'); close $fh_asc or syserr(g_('cannot write signature file %s'), $asc); return $asc; } sub openpgp_sig_to_asc { my ($sig, $asc) = @_; if (-e $sig) { my $is_openpgp_ascii_armor = 0; open my $fh_sig, '<', $sig or syserr(g_('cannot open %s'), $sig); while (<$fh_sig>) { if (m/^-----BEGIN PGP /) { $is_openpgp_ascii_armor = 1; last; } } close $fh_sig; if ($is_openpgp_ascii_armor) { notice(g_('signature file is already OpenPGP ASCII armor, copying')); copy($sig, $asc); return $asc; } if (find_command('gpg')) { return _armor_gpg($sig, $asc); } else { warning(g_('cannot OpenPGP ASCII armor signature file due to missing gpg')); } } return; } sub _exec_openpgp { my ($exec, $exec_opts, $opts, $errmsg) = @_; my ($stdout, $stderr); spawn(exec => $exec, wait_child => 1, nocheck => 1, timeout => 10, to_string => \$stdout, error_to_string => \$stderr, %{$exec_opts}); if (WIFEXITED($?)) { my $status = WEXITSTATUS($?); print { *STDERR } "$stdout$stderr" if $status; if ($status == 1 or ($status && $opts->{require_valid_signature})) { error($errmsg); } elsif ($status) { warning($errmsg); } } else { subprocerr("@{$exec}"); } } sub import_key { my ($asc, %opts) = @_; $opts{require_valid_signature} //= 1; my @exec; if (find_command('gpg')) { push @exec, 'gpg'; } elsif ($opts{require_valid_signature}) { error(g_('cannot import key in %s since GnuPG is not installed'), $asc); } else { warning(g_('cannot import key in %s since GnuPG is not installed'), $asc); return; } my $gpghome = File::Temp->newdir('dpkg-import-key.XXXXXXXX', TMPDIR => 1); push @exec, '--homedir', $gpghome; push @exec, '--no-options', '--no-default-keyring', '-q', '--import'; push @exec, '--keyring', $opts{keyring}; push @exec, $asc; my $errmsg = sprintf g_('cannot import key %s into %s'), $asc, $opts{keyring}; _exec_openpgp(\@exec, {}, \%opts, $errmsg); } sub verify_signature { my ($sig, %opts) = @_; $opts{require_valid_signature} //= 1; my @gpg_weak_digest = map { (qw(--weak-digest), $_) } qw(SHA1 RIPEMD160); my @exec; if (find_command('gpgv')) { push @exec, 'gpgv', @gpg_weak_digest; } elsif (find_command('gpg')) { my @gpg_opts = (qw(--no-options --no-default-keyring -q), @gpg_weak_digest); push @exec, 'gpg', @gpg_opts, '--verify'; } elsif ($opts{require_valid_signature}) { error(g_('cannot verify signature on %s since GnuPG is not installed'), $sig); } else { warning(g_('cannot verify signature on %s since GnuPG is not installed'), $sig); return; } my $gpghome = File::Temp->newdir('dpkg-verify-sig.XXXXXXXX', TMPDIR => 1); push @exec, '--homedir', $gpghome; foreach my $keyring (@{$opts{keyrings}}) { push @exec, '--keyring', $keyring; } push @exec, $sig; push @exec, $opts{datafile} if exists $opts{datafile}; my $errmsg = sprintf g_('cannot verify signature %s'), $sig; _exec_openpgp(\@exec, {}, \%opts, $errmsg); } 1;
Close