diff options
author | Nick Mathewson <nickm@torproject.org> | 2013-03-12 17:36:09 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2013-03-12 17:36:09 -0400 |
commit | 16f2e4aa8ce76387c19687dd0c78c97929a852d6 (patch) | |
tree | 3f289a6454fd81cfe9c8e0187021af5d3e417923 /src/or/connection.c | |
parent | c6ca199888102a825f004f8613331f97525da486 (diff) | |
download | tor-16f2e4aa8ce76387c19687dd0c78c97929a852d6.tar.gz tor-16f2e4aa8ce76387c19687dd0c78c97929a852d6.zip |
Don't warn about not sending a socks reply if we get a write error
If we get a write error on a SOCKS connection, we can't send a
SOCKS reply, now can we?
This bug has been here since 36baf7219, where we added the "hey, I'm
closing an AP connection but I haven't finished the socks
handshake!" message. It's bug 8427.
Diffstat (limited to 'src/or/connection.c')
-rw-r--r-- | src/or/connection.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/or/connection.c b/src/or/connection.c index eac9c4f32b..75c1656206 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -3286,6 +3286,10 @@ connection_handle_write_impl(connection_t *conn, int force) if (result < 0) { if (CONN_IS_EDGE(conn)) connection_edge_end_errno(TO_EDGE_CONN(conn)); + if (conn->type == CONN_TYPE_AP) { + /* writing failed; we couldn't send a SOCKS reply if we wanted to */ + TO_ENTRY_CONN(conn)->socks_request->has_finished = 1; + } connection_close_immediate(conn); /* Don't flush; connection is dead. */ connection_mark_for_close(conn); |