diff options
| author | Tom Lane <tgl@sss.pgh.pa.us> | 2007-08-06 01:38:57 +0000 | 
|---|---|---|
| committer | Tom Lane <tgl@sss.pgh.pa.us> | 2007-08-06 01:38:57 +0000 | 
| commit | 99fa5f458c210c05dd1bb8fdf603f0acc22a0a12 (patch) | |
| tree | b9fc6ba4e3913fbeb62b2177d63157e3fc77c8b4 /src | |
| parent | 681690f4e374d88877ea2f4de1baa04f780abd8e (diff) | |
Fix pg_restore to guard against unexpected EOF while reading an archive file.
Per report and partial patch from Chad Wagner.
Diffstat (limited to 'src')
| -rw-r--r-- | src/bin/pg_dump/pg_backup_archiver.c | 12 | ||||
| -rw-r--r-- | src/bin/pg_dump/pg_backup_custom.c | 11 | ||||
| -rw-r--r-- | src/bin/pg_dump/pg_backup_files.c | 9 | ||||
| -rw-r--r-- | src/bin/pg_dump/pg_backup_tar.c | 13 | 
4 files changed, 25 insertions, 20 deletions
diff --git a/src/bin/pg_dump/pg_backup_archiver.c b/src/bin/pg_dump/pg_backup_archiver.c index 474938dece7..3a9437e444c 100644 --- a/src/bin/pg_dump/pg_backup_archiver.c +++ b/src/bin/pg_dump/pg_backup_archiver.c @@ -15,7 +15,7 @@   *   *   * IDENTIFICATION - *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.62.2.7 2005/05/17 17:31:15 tgl Exp $ + *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.62.2.8 2007/08/06 01:38:57 tgl Exp $   *   *-------------------------------------------------------------------------   */ @@ -1545,7 +1545,7 @@ ReadStr(ArchiveHandle *AH)  	int			l;  	l = ReadInt(AH); -	if (l == -1) +	if (l < 0)  		buf = NULL;  	else  	{ @@ -1553,7 +1553,9 @@ ReadStr(ArchiveHandle *AH)  		if (!buf)  			die_horribly(AH, modulename, "out of memory\n"); -		(*AH->ReadBufPtr) (AH, (void *) buf, l); +		if ((*AH->ReadBufPtr) (AH, (void *) buf, l) != l) +			die_horribly(AH, modulename, "unexpected end of file\n"); +  		buf[l] = '\0';  	} @@ -2277,8 +2279,8 @@ ReadHead(ArchiveHandle *AH)  	/* If we haven't already read the header... */  	if (!AH->readHeader)  	{ - -		(*AH->ReadBufPtr) (AH, tmpMag, 5); +		if ((*AH->ReadBufPtr) (AH, tmpMag, 5) != 5) +			die_horribly(AH, modulename, "unexpected end of file\n");  		if (strncmp(tmpMag, "PGDMP", 5) != 0)  			die_horribly(AH, modulename, "did not find magic string in file header\n"); diff --git a/src/bin/pg_dump/pg_backup_custom.c b/src/bin/pg_dump/pg_backup_custom.c index c2fcef7536e..a15a04aa3ab 100644 --- a/src/bin/pg_dump/pg_backup_custom.c +++ b/src/bin/pg_dump/pg_backup_custom.c @@ -19,7 +19,7 @@   *   *   * IDENTIFICATION - *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.23 2002/10/25 01:33:17 momjian Exp $ + *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.23.2.1 2007/08/06 01:38:57 tgl Exp $   *   *-------------------------------------------------------------------------   */ @@ -713,7 +713,7 @@ _WriteByte(ArchiveHandle *AH, const int i)   *   * Called by the archiver to read bytes & integers from the archive.   * These routines are only used to read & write headers & TOC. - * + * EOF should be treated as a fatal error.   */  static int  _ReadByte(ArchiveHandle *AH) @@ -721,9 +721,10 @@ _ReadByte(ArchiveHandle *AH)  	lclContext *ctx = (lclContext *) AH->formatData;  	int			res; -	res = fgetc(AH->FH); -	if (res != EOF) -		ctx->filePos += 1; +	res = getc(AH->FH); +	if (res == EOF) +		die_horribly(AH, modulename, "unexpected end of file\n"); +	ctx->filePos += 1;  	return res;  } diff --git a/src/bin/pg_dump/pg_backup_files.c b/src/bin/pg_dump/pg_backup_files.c index 3a4914828a5..f9a9264205c 100644 --- a/src/bin/pg_dump/pg_backup_files.c +++ b/src/bin/pg_dump/pg_backup_files.c @@ -20,7 +20,7 @@   *   *   * IDENTIFICATION - *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.21 2002/10/25 01:33:17 momjian Exp $ + *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.21.2.1 2007/08/06 01:38:57 tgl Exp $   *   *-------------------------------------------------------------------------   */ @@ -396,9 +396,10 @@ _ReadByte(ArchiveHandle *AH)  	lclContext *ctx = (lclContext *) AH->formatData;  	int			res; -	res = fgetc(AH->FH); -	if (res != EOF) -		ctx->filePos += 1; +	res = getc(AH->FH); +	if (res == EOF) +		die_horribly(AH, modulename, "unexpected end of file\n"); +	ctx->filePos += 1;  	return res;  } diff --git a/src/bin/pg_dump/pg_backup_tar.c b/src/bin/pg_dump/pg_backup_tar.c index 93293fe8058..2f8169f8535 100644 --- a/src/bin/pg_dump/pg_backup_tar.c +++ b/src/bin/pg_dump/pg_backup_tar.c @@ -16,7 +16,7 @@   *   *   * IDENTIFICATION - *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.32.2.2 2003/02/01 19:29:26 tgl Exp $ + *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.32.2.3 2007/08/06 01:38:57 tgl Exp $   *   *-------------------------------------------------------------------------   */ @@ -484,7 +484,7 @@ _tarReadRaw(ArchiveHandle *AH, void *buf, size_t len, TAR_MEMBER *th, FILE *fh)  			used = avail;  		/* Copy, and adjust buffer pos */ -		memcpy(buf, AH->lookahead, used); +		memcpy(buf, AH->lookahead + AH->lookaheadPos, used);  		AH->lookaheadPos += used;  		/* Adjust required length */ @@ -728,12 +728,13 @@ static int  _ReadByte(ArchiveHandle *AH)  {  	lclContext *ctx = (lclContext *) AH->formatData; -	int			res; -	char		c = '\0'; +	size_t		res; +	unsigned char c;  	res = tarRead(&c, 1, ctx->FH); -	if (res != EOF) -		ctx->filePos += res; +	if (res != 1) +		die_horribly(AH, modulename, "unexpected end of file\n"); +	ctx->filePos += 1;  	return c;  }  | 
