Commit e139bde6 authored by Deomid Ryabkov's avatar Deomid Ryabkov Committed by rojer

A couple SSL-related fixes for Mongoose

    PUBLISHED_FROM=03297850f7a620588de851ef86be25e17a04ad28
parent 5f629511
...@@ -3015,8 +3015,6 @@ static void mg_write_to_socket(struct mg_connection *nc) { ...@@ -3015,8 +3015,6 @@ static void mg_write_to_socket(struct mg_connection *nc) {
int ssl_err = mg_ssl_err(nc, n); int ssl_err = mg_ssl_err(nc, n);
if (ssl_err == SSL_ERROR_WANT_READ || ssl_err == SSL_ERROR_WANT_WRITE) { if (ssl_err == SSL_ERROR_WANT_READ || ssl_err == SSL_ERROR_WANT_WRITE) {
return; /* Call us again */ return; /* Call us again */
} else {
nc->flags |= MG_F_CLOSE_IMMEDIATELY;
} }
} else { } else {
/* Successful SSL operation, clear off SSL wait flags */ /* Successful SSL operation, clear off SSL wait flags */
...@@ -3117,8 +3115,16 @@ static void mg_handle_udp_read(struct mg_connection *nc) { ...@@ -3117,8 +3115,16 @@ static void mg_handle_udp_read(struct mg_connection *nc) {
#ifdef MG_ENABLE_SSL #ifdef MG_ENABLE_SSL
static int mg_ssl_err(struct mg_connection *conn, int res) { static int mg_ssl_err(struct mg_connection *conn, int res) {
int ssl_err = SSL_get_error(conn->ssl, res); int ssl_err = SSL_get_error(conn->ssl, res);
if (ssl_err == SSL_ERROR_WANT_READ) conn->flags |= MG_F_WANT_READ; DBG(("%p %d -> %d", conn, res, ssl_err));
if (ssl_err == SSL_ERROR_WANT_WRITE) conn->flags |= MG_F_WANT_WRITE; if (ssl_err == SSL_ERROR_WANT_READ) {
conn->flags |= MG_F_WANT_READ;
} else if (ssl_err == SSL_ERROR_WANT_WRITE) {
conn->flags |= MG_F_WANT_WRITE;
} else {
/* There could be an alert to deliver. Try our best. */
SSL_write(conn->ssl, "", 0);
conn->flags |= MG_F_CLOSE_IMMEDIATELY;
}
return ssl_err; return ssl_err;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment