From df84a2fcd0903f76f47c6e390cb1b545b1f56f79 Mon Sep 17 00:00:00 2001
From: zzz <zzz@mail.i2p>
Date: Tue, 12 Nov 2013 19:19:21 +0000
Subject: [PATCH] save server status text to return to user

---
 core/java/src/net/i2p/util/EepGet.java | 44 +++++++++++++++++++-------
 1 file changed, 33 insertions(+), 11 deletions(-)

diff --git a/core/java/src/net/i2p/util/EepGet.java b/core/java/src/net/i2p/util/EepGet.java
index 3dbc280c88..93606b2478 100644
--- a/core/java/src/net/i2p/util/EepGet.java
+++ b/core/java/src/net/i2p/util/EepGet.java
@@ -18,7 +18,6 @@ import java.util.Date;
 import java.util.Formatter;
 import java.util.List;
 import java.util.Locale;
-import java.util.StringTokenizer;
 
 import net.i2p.I2PAppContext;
 import net.i2p.data.Base64;
@@ -63,6 +62,7 @@ public class EepGet {
     protected long _bytesRemaining;
     protected int _currentAttempt;
     protected int _responseCode = -1;
+    protected String _responseText;
     protected boolean _shouldWriteErrorToOutput;
     protected String _etag;
     protected String _lastModified;
@@ -732,7 +732,12 @@ public class EepGet {
         if (_transferFailed) {
             // 404, etc - transferFailed is called after all attempts fail, by fetch() above
             if (!_listeners.isEmpty()) {
-                Exception e = new IOException("Attempt failed " + _responseCode);
+                String s;
+                if (_responseText != null)
+                    s = "Attempt failed: " + _responseCode + ' ' + _responseText;
+                else
+                    s = "Attempt failed: " + _responseCode;
+                Exception e = new IOException(s);
                 for (int i = 0; i < _listeners.size(); i++)  {
                     _listeners.get(i).attemptFailed(_url, _bytesTransferred, _bytesRemaining, _currentAttempt,
                                                     _numRetries, e);
@@ -947,25 +952,25 @@ public class EepGet {
      * e.g. "HTTP/1.1 206 OK" vs "HTTP/1.1 200 OK" vs 
      * "HTTP/1.1 404 NOT FOUND", etc.  
      *
+     * Side effect - stores status text in _responseText
+     *
      * @return HTTP response code (200, 206, other)
      */
     private int handleStatus(String line) {
         if (_log.shouldLog(Log.DEBUG))
             _log.debug("Status line: [" + line + "]");
-        StringTokenizer tok = new StringTokenizer(line, " ");
-        if (!tok.hasMoreTokens()) {
-            if (_log.shouldLog(Log.WARN))
-                _log.warn("ERR: status "+  line);
-            return -1;
-        }
-        tok.nextToken(); // ignored (protocol)
-        if (!tok.hasMoreTokens()) {
+        String[] toks = line.split(" ", 3);
+        if (toks.length < 2) {
             if (_log.shouldLog(Log.WARN))
                 _log.warn("ERR: status "+  line);
             return -1;
         }
-        String rc = tok.nextToken();
+        String rc = toks[1];
         try {
+            if (toks.length >= 3)
+                _responseText = toks[2].trim();
+            else
+                _responseText = null;
             return Integer.parseInt(rc); 
         } catch (NumberFormatException nfe) {
             if (_log.shouldLog(Log.WARN))
@@ -1195,6 +1200,23 @@ public class EepGet {
     public int getStatusCode() {
         return _responseCode;
     }
+    
+    /**
+     *  The server text ("OK", "Not Found",  etc).
+     *  Note that the text may contain % encoding.
+     *
+     *  @return null if invalid, or if the proxy never responded,
+     *  or if no proxy was used and the server never responded.
+     *  If a non-proxied request partially succeeded (for example a redirect followed
+     *  by a fail, or a partial fetch followed by a fail), this will
+     *  be the last status code received.
+     *  Note that fetch() may return false even if this returns "OK".
+     *
+      *  @since 0.9.9
+     */
+    public String getStatusText() {
+        return _responseText;
+    }
 
     /**
      *  If called (before calling fetch()),
-- 
GitLab