[ https://issues.apache.org/jira/browse/IO-71?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12568559#action_12568559 ]
David Smiley commented on IO-71: -------------------------------- I agree with what you're saying. But as far as it being "not too much of an issue"... I wonder if the risk isn't so much "normal expected data" but instead a security concern resulting in a denial of service. Lets say hypothetically that we had some decompressing outputstream. So if the input size is X, then the output would generally be larger than X (and hence the requirements of our buffer). In normal data the ratio might be a ratio of say 1:10 and since your code requests data in 1KB chunks, it'd need a 10KB buffer. But an attacker might give this system data that has an extreme compression ratio of say 1:100000000000 (lots of zeroes, whatever). Like say a 100MB file consisting of all one's which would compress like mad. A system based on this code would then consume all available memory and more or less crash. The size of the input file needed to cause this to occur depends on both the deployed environment and the compression ratio achievable. I admit I'm sort of a perfectionist so I may be making a bigger deal out of this than is warranted. If you really do insist on a variation of your solution, I recommend you have internal warning thresholds which cause warnings to be logged beyond certain thresholds to alert people of a potential problem. > [io] PipedUtils > --------------- > > Key: IO-71 > URL: https://issues.apache.org/jira/browse/IO-71 > Project: Commons IO > Issue Type: Improvement > Components: Utilities > Environment: Operating System: All > Platform: All > Reporter: David Smiley > Priority: Minor > Fix For: 2.x > > Attachments: PipedUtils.zip, ReverseFilterOutputStream.patch > > > I developed some nifty code that takes an OutputStream and sort of reverses > it as if it were an > InputStream. Error passing and handling close is dealt with. It needs > another thread to do the work > which runs in parallel. It uses Piped streams. I created this because I > had to conform > GZIPOutputStream to my framework which demanded an InputStream. > See URL to source. -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online.