From a97d5c15b713f69ba6928cc89229b84969e355e0 Mon Sep 17 00:00:00 2001 From: Joakim Erdfelt Date: Tue, 16 Oct 2007 01:29:31 +0000 Subject: [PATCH] Fixing GET vs PUT logic. Encountered a situation where a PUT could result in a 404. git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@584992 13f79535-47bb-0310-9956-ffa450edef68 --- .../web/repository/ProxiedDavServer.java | 38 ++++++++++++------- 1 file changed, 25 insertions(+), 13 deletions(-) diff --git a/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/repository/ProxiedDavServer.java b/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/repository/ProxiedDavServer.java index 07b58c5bb..cfa63a093 100644 --- a/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/repository/ProxiedDavServer.java +++ b/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/repository/ProxiedDavServer.java @@ -132,11 +132,15 @@ public class ProxiedDavServer public void process( DavServerRequest request, HttpServletResponse response ) throws DavServerException, ServletException, IOException { - if ( WebdavMethodUtil.isReadMethod( request.getRequest().getMethod() ) ) + boolean isGet = WebdavMethodUtil.isReadMethod( request.getRequest().getMethod() ); + boolean isPut = WebdavMethodUtil.isWriteMethod( request.getRequest().getMethod() ); + + if ( isGet ) { fetchContentFromProxies( request ); } - else + + if ( isPut ) { /* Create parent directories that don't exist when writing a file * This actually makes this implementation not compliant to the @@ -153,23 +157,31 @@ public class ProxiedDavServer } } - // [MRM-503] - Metadata file need Pragma:no-cache response header. - if ( request.getLogicalResource().endsWith( "/maven-metadata.xml" ) ) + if ( isGet ) { - response.addHeader( "Pragma", "no-cache" ); - response.addHeader( "Cache-Control", "no-cache" ); + if ( resourceExists( request ) ) + { + // [MRM-503] - Metadata file need Pragma:no-cache response header. + if ( request.getLogicalResource().endsWith( "/maven-metadata.xml" ) ) + { + response.addHeader( "Pragma", "no-cache" ); + response.addHeader( "Cache-Control", "no-cache" ); + } + + // TODO: [MRM-524] determine http caching options for other types of files (artifacts, sha1, md5, snapshots) + + davServer.process( request, response ); + } + else + { + respondResourceMissing( request, response ); + } } - // TODO: [MRM-524] determine http caching options for other types of files (artifacts, sha1, md5, snapshots) - - if( resourceExists( request ) ) + if ( isPut ) { davServer.process( request, response ); } - else - { - respondResourceMissing( request, response ); - } } private void respondResourceMissing( DavServerRequest request, HttpServletResponse response )