diff options
-rw-r--r-- | org.eclipse.jgit.http.server/src/org/eclipse/jgit/http/server/UploadPackServlet.java | 57 |
1 files changed, 29 insertions, 28 deletions
diff --git a/org.eclipse.jgit.http.server/src/org/eclipse/jgit/http/server/UploadPackServlet.java b/org.eclipse.jgit.http.server/src/org/eclipse/jgit/http/server/UploadPackServlet.java index b0a07f1d5d..f16e56d949 100644 --- a/org.eclipse.jgit.http.server/src/org/eclipse/jgit/http/server/UploadPackServlet.java +++ b/org.eclipse.jgit.http.server/src/org/eclipse/jgit/http/server/UploadPackServlet.java @@ -168,40 +168,41 @@ class UploadPackServlet extends HttpServlet { } UploadPackRunnable r = () -> { - UploadPack up = (UploadPack) req.getAttribute(ATTRIBUTE_HANDLER); - // to be explicitly closed by caller - @SuppressWarnings("resource") - SmartOutputStream out = new SmartOutputStream(req, rsp, false) { - @Override - public void flush() throws IOException { - doFlush(); - } - }; + upload(req, rsp); + }; + handler.upload(req, rsp, r); + } + + private void upload(HttpServletRequest req, HttpServletResponse rsp) + throws IOException, ServiceMayNotContinueException { + // to be explicitly closed by caller + @SuppressWarnings("resource") + SmartOutputStream out = new SmartOutputStream(req, rsp, false) { + @Override + public void flush() throws IOException { + doFlush(); + } + }; + Repository repo = null; + try (UploadPack up = (UploadPack) req.getAttribute(ATTRIBUTE_HANDLER)) { up.setBiDirectionalPipe(false); rsp.setContentType(UPLOAD_PACK_RESULT_TYPE); - - try { - up.uploadWithExceptionPropagation(getInputStream(req), out, - null); - out.close(); - } catch (ServiceMayNotContinueException e) { - if (e.isOutput()) { - consumeRequestBody(req); - out.close(); - } - throw e; - } catch (UploadPackInternalServerErrorException e) { - // Special case exception, error message was sent to client. - log(up.getRepository(), e.getCause()); + repo = up.getRepository(); + up.uploadWithExceptionPropagation(getInputStream(req), out, null); + out.close(); + } catch (ServiceMayNotContinueException e) { + if (e.isOutput()) { consumeRequestBody(req); out.close(); - } finally { - up.close(); } - }; - - handler.upload(req, rsp, r); + throw e; + } catch (UploadPackInternalServerErrorException e) { + // Special case exception, error message was sent to client. + log(repo, e.getCause()); + consumeRequestBody(req); + out.close(); + } } private void defaultUploadPackHandler(HttpServletRequest req, |