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