]> source.dussan.org Git - jgit.git/commit
Fix error handling in FileLfsServlet 02/129502/2
authorMatthias Sohn <matthias.sohn@sap.com>
Sun, 16 Sep 2018 22:35:33 +0000 (00:35 +0200)
committerMatthias Sohn <matthias.sohn@sap.com>
Mon, 17 Sep 2018 15:48:55 +0000 (17:48 +0200)
commitc18c768678094dba36e4d394de7a673d1a8764c4
tree97bf8c83da267082dc6706f8aef4822bcf5cbeec
parent5c134f4d42e12e9192f2beca8370c1b8bd58c08d
Fix error handling in FileLfsServlet

Check in #sendError method if the response was committed already.

If yes we cannot set response status or send an error message, last
resort is to close the outputstream.

If the response wasn't yet committed first reset the response before
using writer to send the error message to the client since mixing STREAM
and WRITE mode (mixing asynchronous and blocking I/O) is illegal in
servlet 3.1.

see the following bugs in the gerrit and jetty issue trackers
https://bugs.chromium.org/p/gerrit/issues/detail?id=9667
https://bugs.chromium.org/p/gerrit/issues/detail?id=9721
https://github.com/eclipse/jetty.project/issues/2911

Change-Id: Ie35563c2e0ac1c5e918185a746622589a880dc7f
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
org.eclipse.jgit.lfs.server/src/org/eclipse/jgit/lfs/server/fs/FileLfsServlet.java