mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-17 14:07:03 +01:00
gpgtar: Print a result status with skipped files.
* tools/gpgtar.h (struct tarinfo_s): Add new fields. * tools/gpgtar-extract.c (check_suspicious_name): Add arg info. (extract_regular): Count files. (gpgtar_extract): Print stats.
This commit is contained in:
parent
ed9a420a22
commit
0045583cd2
11
doc/DETAILS
11
doc/DETAILS
@ -1138,6 +1138,17 @@ pkd:0:1024:B665B1435F4C2 .... FF26ABB:
|
|||||||
send to the client instead of this status line. Such an inquiry
|
send to the client instead of this status line. Such an inquiry
|
||||||
may be used to sync with Pinentry
|
may be used to sync with Pinentry
|
||||||
|
|
||||||
|
*** GPGTAR_EXTRACT <tot> <skp> <bad> <sus> <sym> <hrd> <oth>
|
||||||
|
This status line is emitted after gpgtar has extracted files.
|
||||||
|
|
||||||
|
- tot :: Total number of files extracted and stored
|
||||||
|
- skp :: Total number of files skipped during extraction
|
||||||
|
- bad :: Number of files skipped due to a bad file name
|
||||||
|
- sus :: Number of files skipped due to a suspicious file name
|
||||||
|
- sym :: Number of symlinks not restored
|
||||||
|
- hrd :: Number of hard links not restored
|
||||||
|
- oth :: Number of files not extracted due to other reasons.
|
||||||
|
|
||||||
** Obsolete status codes
|
** Obsolete status codes
|
||||||
*** SIGEXPIRED
|
*** SIGEXPIRED
|
||||||
Removed on 2011-02-04. This is deprecated in favor of KEYEXPIRED.
|
Removed on 2011-02-04. This is deprecated in favor of KEYEXPIRED.
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
#include "gpgtar.h"
|
#include "gpgtar.h"
|
||||||
|
|
||||||
static gpg_error_t
|
static gpg_error_t
|
||||||
check_suspicious_name (const char *name)
|
check_suspicious_name (const char *name, tarinfo_t info)
|
||||||
{
|
{
|
||||||
size_t n;
|
size_t n;
|
||||||
|
|
||||||
@ -47,6 +47,7 @@ check_suspicious_name (const char *name)
|
|||||||
{
|
{
|
||||||
log_error ("filename '%s' contains a backslash - "
|
log_error ("filename '%s' contains a backslash - "
|
||||||
"can't extract on this system\n", name);
|
"can't extract on this system\n", name);
|
||||||
|
info->skipped_badname++;
|
||||||
return gpg_error (GPG_ERR_INV_NAME);
|
return gpg_error (GPG_ERR_INV_NAME);
|
||||||
}
|
}
|
||||||
#endif /*HAVE_DOSISH_SYSTEM*/
|
#endif /*HAVE_DOSISH_SYSTEM*/
|
||||||
@ -59,6 +60,7 @@ check_suspicious_name (const char *name)
|
|||||||
{
|
{
|
||||||
log_error ("filename '%s' has suspicious parts - not extracting\n",
|
log_error ("filename '%s' has suspicious parts - not extracting\n",
|
||||||
name);
|
name);
|
||||||
|
info->skipped_suspicious++;
|
||||||
return gpg_error (GPG_ERR_INV_NAME);
|
return gpg_error (GPG_ERR_INV_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,7 +85,7 @@ extract_regular (estream_t stream, const char *dirname,
|
|||||||
if (sl->flags == 1)
|
if (sl->flags == 1)
|
||||||
fname = sl->d;
|
fname = sl->d;
|
||||||
|
|
||||||
err = check_suspicious_name (fname);
|
err = check_suspicious_name (fname, info);
|
||||||
if (err)
|
if (err)
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
@ -131,8 +133,12 @@ extract_regular (estream_t stream, const char *dirname,
|
|||||||
/* Fixme: Set permissions etc. */
|
/* Fixme: Set permissions etc. */
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
if (!err && opt.verbose)
|
if (!err)
|
||||||
log_info ("extracted '%s'\n", fname);
|
{
|
||||||
|
if (opt.verbose)
|
||||||
|
log_info ("extracted '%s'\n", fname);
|
||||||
|
info->nextracted++;
|
||||||
|
}
|
||||||
es_fclose (outfp);
|
es_fclose (outfp);
|
||||||
if (err && fname && outfp)
|
if (err && fname && outfp)
|
||||||
{
|
{
|
||||||
@ -146,7 +152,8 @@ extract_regular (estream_t stream, const char *dirname,
|
|||||||
|
|
||||||
|
|
||||||
static gpg_error_t
|
static gpg_error_t
|
||||||
extract_directory (const char *dirname, tar_header_t hdr, strlist_t exthdr)
|
extract_directory (const char *dirname, tarinfo_t info,
|
||||||
|
tar_header_t hdr, strlist_t exthdr)
|
||||||
{
|
{
|
||||||
gpg_error_t err;
|
gpg_error_t err;
|
||||||
const char *name;
|
const char *name;
|
||||||
@ -158,7 +165,7 @@ extract_directory (const char *dirname, tar_header_t hdr, strlist_t exthdr)
|
|||||||
if (sl->flags == 1)
|
if (sl->flags == 1)
|
||||||
name = sl->d;
|
name = sl->d;
|
||||||
|
|
||||||
err = check_suspicious_name (name);
|
err = check_suspicious_name (name, info);
|
||||||
if (err)
|
if (err)
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
@ -231,13 +238,19 @@ extract (estream_t stream, const char *dirname, tarinfo_t info,
|
|||||||
if (hdr->typeflag == TF_REGULAR || hdr->typeflag == TF_UNKNOWN)
|
if (hdr->typeflag == TF_REGULAR || hdr->typeflag == TF_UNKNOWN)
|
||||||
err = extract_regular (stream, dirname, info, hdr, exthdr);
|
err = extract_regular (stream, dirname, info, hdr, exthdr);
|
||||||
else if (hdr->typeflag == TF_DIRECTORY)
|
else if (hdr->typeflag == TF_DIRECTORY)
|
||||||
err = extract_directory (dirname, hdr, exthdr);
|
err = extract_directory (dirname, info, hdr, exthdr);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
char record[RECORDSIZE];
|
char record[RECORDSIZE];
|
||||||
|
|
||||||
log_info ("unsupported file type %d for '%s' - skipped\n",
|
log_info ("unsupported file type %d for '%s' - skipped\n",
|
||||||
(int)hdr->typeflag, hdr->name);
|
(int)hdr->typeflag, hdr->name);
|
||||||
|
if (hdr->typeflag == TF_SYMLINK)
|
||||||
|
info->skipped_symlinks++;
|
||||||
|
else if (hdr->typeflag == TF_HARDLINK)
|
||||||
|
info->skipped_hardlinks++;
|
||||||
|
else
|
||||||
|
info->skipped_other++;
|
||||||
for (err = 0, n=0; !err && n < hdr->nrecords; n++)
|
for (err = 0, n=0; !err && n < hdr->nrecords; n++)
|
||||||
{
|
{
|
||||||
err = read_record (stream, record);
|
err = read_record (stream, record);
|
||||||
@ -329,7 +342,7 @@ gpgtar_extract (const char *filename, int decrypt)
|
|||||||
tarinfo_t tarinfo = &tarinfo_buffer;
|
tarinfo_t tarinfo = &tarinfo_buffer;
|
||||||
pid_t pid = (pid_t)(-1);
|
pid_t pid = (pid_t)(-1);
|
||||||
char *logfilename = NULL;
|
char *logfilename = NULL;
|
||||||
|
unsigned long long notextracted;
|
||||||
|
|
||||||
memset (&tarinfo_buffer, 0, sizeof tarinfo_buffer);
|
memset (&tarinfo_buffer, 0, sizeof tarinfo_buffer);
|
||||||
|
|
||||||
@ -480,8 +493,37 @@ gpgtar_extract (const char *filename, int decrypt)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
|
notextracted = tarinfo->skipped_badname;
|
||||||
|
notextracted += tarinfo->skipped_suspicious;
|
||||||
|
notextracted += tarinfo->skipped_symlinks;
|
||||||
|
notextracted += tarinfo->skipped_hardlinks;
|
||||||
|
notextracted += tarinfo->skipped_other;
|
||||||
|
if (opt.status_stream)
|
||||||
|
es_fprintf (opt.status_stream, "[GNUPG:] GPGTAR_EXTRACT"
|
||||||
|
" %llu %llu %lu %lu %lu %lu %lu\n",
|
||||||
|
tarinfo->nextracted,
|
||||||
|
notextracted,
|
||||||
|
tarinfo->skipped_badname,
|
||||||
|
tarinfo->skipped_suspicious,
|
||||||
|
tarinfo->skipped_symlinks,
|
||||||
|
tarinfo->skipped_hardlinks,
|
||||||
|
tarinfo->skipped_other);
|
||||||
|
if (notextracted && !opt.quiet)
|
||||||
|
{
|
||||||
|
log_info ("Number of files not extracted: %llu\n", notextracted);
|
||||||
|
if (tarinfo->skipped_badname)
|
||||||
|
log_info (" invalid name: %lu\n", tarinfo->skipped_badname);
|
||||||
|
if (tarinfo->skipped_suspicious)
|
||||||
|
log_info (" suspicious name: %lu\n", tarinfo->skipped_suspicious);
|
||||||
|
if (tarinfo->skipped_symlinks)
|
||||||
|
log_info (" symlink: %lu\n", tarinfo->skipped_symlinks);
|
||||||
|
if (tarinfo->skipped_hardlinks)
|
||||||
|
log_info (" hardlink: %lu\n", tarinfo->skipped_hardlinks);
|
||||||
|
if (tarinfo->skipped_other)
|
||||||
|
log_info (" other reason: %lu\n", tarinfo->skipped_other);
|
||||||
|
}
|
||||||
|
|
||||||
free_strlist (extheader);
|
free_strlist (extheader);
|
||||||
xfree (header);
|
xfree (header);
|
||||||
xfree (dirname);
|
xfree (dirname);
|
||||||
|
@ -487,7 +487,7 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
/* Set status stream for our own use of --status-fd. The original
|
/* Set status stream for our own use of --status-fd. The original
|
||||||
* status fd is passed verbatim to gpg. */
|
* status fd is passed verbatim to gpg. */
|
||||||
if (opt.status_fd)
|
if (opt.status_fd != -1)
|
||||||
{
|
{
|
||||||
int fd = translate_sys2libc_fd_int (opt.status_fd, 1);
|
int fd = translate_sys2libc_fd_int (opt.status_fd, 1);
|
||||||
|
|
||||||
|
@ -54,8 +54,14 @@ struct
|
|||||||
/* An info structure to avoid global variables. */
|
/* An info structure to avoid global variables. */
|
||||||
struct tarinfo_s
|
struct tarinfo_s
|
||||||
{
|
{
|
||||||
unsigned long long nblocks; /* Count of processed blocks. */
|
unsigned long long nblocks; /* Count of processed blocks. */
|
||||||
unsigned long long headerblock; /* Number of current header block. */
|
unsigned long long headerblock; /* Number of current header block. */
|
||||||
|
unsigned long long nextracted; /* Number of extracted files. */
|
||||||
|
unsigned long skipped_badname;
|
||||||
|
unsigned long skipped_suspicious;
|
||||||
|
unsigned long skipped_symlinks;
|
||||||
|
unsigned long skipped_hardlinks;
|
||||||
|
unsigned long skipped_other;
|
||||||
};
|
};
|
||||||
typedef struct tarinfo_s *tarinfo_t;
|
typedef struct tarinfo_s *tarinfo_t;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user