Files
webmin/filemin/extract.cgi
Ilia Ross 04ae776e6a
Some checks failed
webmin.dev: webmin/webmin / build (push) Has been cancelled
Fix to validate action paths
* Note: Validate File Manager action name/file parameters as checked paths under the current directory and `allowed_paths` before operations, blocking traversal and symlink escapes.
2026-05-12 01:25:57 +02:00

71 lines
1.5 KiB
Perl
Executable File

#!/usr/local/bin/perl
require './filemin-lib.pl';
&ReadParse();
get_paths();
my $name = $in{'file'};
my $full = &validate_filename_path($name);
$archive_type = clean_mimetype($full);
if ($archive_type =~ /x-bzip/) {
$cmd = "tar xvjfp ".
quotemeta($full).
" -C ".quotemeta($cwd);
}
elsif ($archive_type =~
/x-tar|\/gzip|x-xz|zstd|x-compressed-tar/) {
$cmd = "tar xfp ".
quotemeta($full).
" -C ".quotemeta($cwd);
}
elsif ($archive_type =~ /x-7z/ ||
$archive_type =~ /x-raw-disk-image/ ||
$archive_type =~ /x-cd-image/) {
$cmd = "7z x ".
quotemeta($full).
" -o".quotemeta($cwd);
}
elsif ($archive_type =~ /\/zip/) {
my $unzip_out = `unzip --help`;
my $uu = ($unzip_out =~ /-UU/ ? '-UU' : undef);
$cmd = "unzip $uu -q -o ".
quotemeta($full).
" -d ".quotemeta($cwd);
}
elsif ($archive_type =~ /\/x-rar|\/vnd\.rar/) {
$cmd = "unrar x -r -y ".
quotemeta($full).
" ".quotemeta($cwd);
}
elsif ($archive_type =~ /(\/x-rpm|\/x-deb)/) {
my ($dir) = fileparse($full, qr/\.[^.]*/);
my $path = &validate_filename_path($dir);
&make_dir($path, 0755);
if ($archive_type =~ /\/x-rpm/) {
$cmd = "(rpm2cpio ".
quotemeta($full).
" | (cd ".quotemeta($path).
"; cpio -idmv))";
}
else {
$cmd = "dpkg -x ".
quotemeta($full).
" ".quotemeta($path);
}
}
else {
&error($text{'extract_etype'});
}
# Run the extraction command
$out = &backquote_logged(
"$cmd 2>&1 >/dev/null </dev/null");
if ($?) {
&error(&html_escape($out));
}
&redirect("index.cgi?path=".&urlize($path));