]> source.dussan.org Git - archiva.git/commitdiff
add a wagon transfert listener for debugging purpose
authorOlivier Lamy <olamy@apache.org>
Fri, 30 Sep 2011 09:41:47 +0000 (09:41 +0000)
committerOlivier Lamy <olamy@apache.org>
Fri, 30 Sep 2011 09:41:47 +0000 (09:41 +0000)
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1177571 13f79535-47bb-0310-9956-ffa450edef68

archiva-modules/archiva-base/archiva-proxy-common/src/main/java/org/apache/archiva/proxy/common/DebugTransferListener.java [new file with mode: 0644]
archiva-modules/archiva-base/archiva-proxy-common/src/main/java/org/apache/archiva/proxy/common/DefaultWagonFactory.java
archiva-modules/archiva-web/archiva-rest/archiva-rest-services/pom.xml
archiva-modules/archiva-web/archiva-webapp/src/test/resources/log4j.xml

diff --git a/archiva-modules/archiva-base/archiva-proxy-common/src/main/java/org/apache/archiva/proxy/common/DebugTransferListener.java b/archiva-modules/archiva-base/archiva-proxy-common/src/main/java/org/apache/archiva/proxy/common/DebugTransferListener.java
new file mode 100644 (file)
index 0000000..226a118
--- /dev/null
@@ -0,0 +1,73 @@
+package org.apache.archiva.proxy.common;
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License.  You may obtain a copy of the License at
+ *
+ *   http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied.  See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import org.apache.maven.wagon.events.TransferEvent;
+import org.apache.maven.wagon.events.TransferListener;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.util.Arrays;
+
+/**
+ * @author Olivier Lamy
+ * @since 1.4
+ */
+public class DebugTransferListener
+    implements TransferListener
+{
+    private Logger log = LoggerFactory.getLogger( getClass() );
+
+    public void transferInitiated( TransferEvent transferEvent )
+    {
+        log.debug( "transferInitiated for resource {} on repository url {}", transferEvent.getResource().getName(),
+                   transferEvent.getWagon().getRepository().getUrl() );
+    }
+
+    public void transferStarted( TransferEvent transferEvent )
+    {
+        log.debug( "transferStarted for resource {} on repository url {}", transferEvent.getResource().getName(),
+                   transferEvent.getWagon().getRepository().getUrl() );
+    }
+
+    public void transferProgress( TransferEvent transferEvent, byte[] bytes, int i )
+    {
+        log.debug( "transferProgress for resource {} on repository url {}", transferEvent.getResource().getName(),
+                   transferEvent.getWagon().getRepository().getUrl() );
+    }
+
+    public void transferCompleted( TransferEvent transferEvent )
+    {
+        log.debug( "transferCompleted for resource {} on repository url {}", transferEvent.getResource().getName(),
+                   transferEvent.getWagon().getRepository().getUrl() );
+    }
+
+    public void transferError( TransferEvent transferEvent )
+    {
+        log.debug( "transferError for resource {} on repository url {}",
+                   Arrays.asList( transferEvent.getResource().getName(),
+                                  transferEvent.getWagon().getRepository().getUrl() ).toArray( new String[2] ),
+                   transferEvent.getException() );
+    }
+
+    public void debug( String s )
+    {
+        log.debug( "wagon debug {}", s );
+    }
+}
index f2631c05129c35036bad8faff21058fe81e59e97..9316bbf49af7db3ca20279cc6b0c0b49caeab3b6 100755 (executable)
@@ -38,6 +38,8 @@ public class DefaultWagonFactory
 
     private PlexusSisuBridge plexusSisuBridge;
 
+    private DebugTransferListener debugTransferListener = new DebugTransferListener();
+
     @Inject
     public DefaultWagonFactory( PlexusSisuBridge plexusSisuBridge )
     {
@@ -52,7 +54,9 @@ public class DefaultWagonFactory
             // with sisu inject bridge hint is file or http
             // so remove wagon#
             protocol = StringUtils.remove( protocol, "wagon#" );
-            return plexusSisuBridge.lookup( Wagon.class, protocol );
+            Wagon wagon = plexusSisuBridge.lookup( Wagon.class, protocol );
+            wagon.addTransferListener( debugTransferListener );
+            return wagon;
         }
         catch ( PlexusSisuBridgeException e )
         {
index 8ab8092ead8bacc02300bb671c9728a9fd1d73e4..120d30eadeaaf13b4fb59413e4863d3d0c662062 100644 (file)
@@ -30,7 +30,7 @@
 
   <properties>
     <jettyVersion>7.4.5.v20110725</jettyVersion>
-    <archiva.base.admUrl></archiva.baseRestUrl>
+    <archiva.baseRestUrl></archiva.baseRestUrl>
     <rest.admin.pwd></rest.admin.pwd>
   </properties>
 
index 7adf8c8c4a4827b2f07e0fc5e6c556214c66c265..3c086ce6db81bc98129bc4325f0049549825e0cc 100644 (file)
   <logger name="JPOX">
     <level value="error"/>
   </logger>
+  <!-- debug wagon transfer -->
+  <logger name="org.apache.archiva.proxy.common">
+    <level value="debug"/>
+  </logger>
+  <!-- apache httpclient debug content transfer-->
+  <!--
+  <logger name="org.apache.http.wire">
+    <level value="debug"/>
+  </logger>
+  -->
+  <logger name="org.apache.http.wire.header">
+    <level value="debug"/>
+  </logger>
+
 
   <logger name="org.apache.commons.configuration.DefaultConfigurationBuilder">
     <level value="error"/>