From: Brett Porter Date: Wed, 25 Jun 2014 04:22:18 +0000 (+1000) Subject: [MRM-1796] support artifacts larger than 4G X-Git-Tag: archiva-2.1.0~12 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=48a42e895ad413c5cf9e08382368d58661b20110;p=archiva.git [MRM-1796] support artifacts larger than 4G [MRM-1796] support artifacts larger than 4G --- diff --git a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResource.java b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResource.java index c1c73eee8..2257467b4 100644 --- a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResource.java +++ b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResource.java @@ -35,6 +35,7 @@ import org.apache.archiva.webdav.util.MimeTypes; import org.apache.commons.io.FileUtils; import org.apache.commons.io.IOUtils; import org.apache.jackrabbit.util.Text; +import org.apache.jackrabbit.webdav.DavConstants; import org.apache.jackrabbit.webdav.DavException; import org.apache.jackrabbit.webdav.DavResource; import org.apache.jackrabbit.webdav.DavResourceFactory; @@ -211,7 +212,8 @@ public class ArchivaDavResource { if ( !isCollection() ) { - outputContext.setContentLength( localResource.length() ); + //outputContext.setContentLength( localResource.length() ); + outputContext.setProperty( DavConstants.HEADER_CONTENT_LENGTH, Long.toString( localResource.length() ) ); outputContext.setContentType( mimeTypes.getMimeType( localResource.getName() ) ); } @@ -329,7 +331,8 @@ public class ArchivaDavResource } // TODO: a bad deployment shouldn't delete an existing file - do we need to write to a temporary location first? - long expectedContentLength = inputContext.getContentLength(); + //long expectedContentLength = inputContext.getContentLength(); + long expectedContentLength = Long.parseLong( inputContext.getProperty( DavConstants.HEADER_CONTENT_LENGTH ) ); long actualContentLength = localFile.length(); // length of -1 is given for a chunked request or unknown length, in which case we accept what was uploaded if ( expectedContentLength >= 0 && expectedContentLength != actualContentLength )