Skip to content

Commit

Permalink
Throw exception on Store+Descriptor entries
Browse files Browse the repository at this point in the history
  • Loading branch information
piksel committed Oct 3, 2020
1 parent 61d3a21 commit fc20370
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 0 deletions.
15 changes: 15 additions & 0 deletions src/ICSharpCode.SharpZipLib/Zip/ZipInputStream.cs
Original file line number Diff line number Diff line change
Expand Up @@ -493,6 +493,14 @@ private int ReadingNotSupported(byte[] destination, int offset, int count)
throw new ZipException("The compression method for this entry is not supported");
}

/// <summary>
/// Handle attempts to read from this entry by throwing an exception
/// </summary>
private int StoredDescriptorEntry(byte[] destination, int offset, int count) =>
throw new StreamUnsupportedException(
"The combination of Stored compression method and Descriptor flag is not possible to read using ZipInputStream");


/// <summary>
/// Perform the initial read on an entry which may include
/// reading encryption headers and setting up inflation.
Expand Down Expand Up @@ -551,6 +559,13 @@ private int InitialRead(byte[] destination, int offset, int count)
inputBuffer.SetInflaterInput(inf);
}

// It's not possible to know how many bytes to read when using "Stored" compression
if (method == CompressionMethod.Stored)
{
internalReader = StoredDescriptorEntry;
return StoredDescriptorEntry(destination, offset, count);
}

internalReader = new ReadDataHandler(BodyRead);
return BodyRead(destination, offset, count);
}
Expand Down
36 changes: 36 additions & 0 deletions test/ICSharpCode.SharpZipLib.Tests/Zip/StreamHandling.cs
Original file line number Diff line number Diff line change
Expand Up @@ -502,5 +502,41 @@ public void ShouldBeAbleToReadEntriesWithInvalidFileNames()
}
}
}

[Test]
[Category("Zip")]
public void ShouldThrowDescriptiveExceptionOnUncompressedDescriptorEntry()
{
using (var ms = new MemoryStreamWithoutSeek())
{
using (var zos = new ZipOutputStream(ms))
{
zos.IsStreamOwner = false;
var entry = new ZipEntry("testentry");
entry.CompressionMethod = CompressionMethod.Stored;
entry.Flags |= (int)GeneralBitFlags.Descriptor;
zos.PutNextEntry(entry);
zos.Write(new byte[1], 0, 1);
zos.CloseEntry();
}

// Patch the Compression Method, since ZipOutputStream automatically changes it to Deflate when descriptors are used
ms.Seek(8, SeekOrigin.Begin);
ms.WriteByte((byte)CompressionMethod.Stored);
ms.Seek(0, SeekOrigin.Begin);

using (var zis = new ZipInputStream(ms))
{
zis.IsStreamOwner = false;
var buf = new byte[32];
zis.GetNextEntry();

Assert.Throws(typeof(StreamUnsupportedException), () =>
{
zis.Read(buf, 0, buf.Length);
});
}
}
}
}
}

0 comments on commit fc20370

Please sign in to comment.