aboutsummaryrefslogtreecommitdiffstats
path: root/src/libutil
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-14 10:14:56 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-14 10:14:56 +0100
commit7fd590aabff817d200a3946872c8d0938e55814f (patch)
treed802709e9e5c0f77398bdedf9e41be7abd4581f6 /src/libutil
parent7dd96f361e62a95ef1c125a21bde385ea5bd8006 (diff)
downloadrspamd-7fd590aabff817d200a3946872c8d0938e55814f.tar.gz
rspamd-7fd590aabff817d200a3946872c8d0938e55814f.zip
[Fix] More fixes to events logic
Diffstat (limited to 'src/libutil')
-rw-r--r--src/libutil/ssl_util.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/libutil/ssl_util.c b/src/libutil/ssl_util.c
index a72f1de95..55d5a1ad4 100644
--- a/src/libutil/ssl_util.c
+++ b/src/libutil/ssl_util.c
@@ -382,6 +382,7 @@ rspamd_ssl_event_handler (gint fd, short what, gpointer ud)
return;
}
+ event_del (c->ev);
event_set (c->ev, fd, what, rspamd_ssl_event_handler, c);
event_base_set (c->ev_base, c->ev);
event_add (c->ev, c->tv);
@@ -389,12 +390,22 @@ rspamd_ssl_event_handler (gint fd, short what, gpointer ud)
break;
case ssl_next_read:
event_del (c->ev);
+ /* Restore handler */
+ event_set (c->ev, c->fd, EV_READ|EV_PERSIST,
+ c->handler, c->handler_data);
+ event_base_set (c->ev_base, c->ev);
+ event_add (c->ev, c->tv);
c->state = ssl_conn_connected;
c->handler (fd, EV_READ, c->handler_data);
break;
case ssl_next_write:
case ssl_conn_connected:
event_del (c->ev);
+ /* Restore handler */
+ event_set (c->ev, c->fd, EV_WRITE,
+ c->handler, c->handler_data);
+ event_base_set (c->ev_base, c->ev);
+ event_add (c->ev, c->tv);
c->state = ssl_conn_connected;
c->handler (fd, EV_WRITE, c->handler_data);
break;
@@ -459,6 +470,11 @@ rspamd_ssl_connect_fd (struct rspamd_ssl_connection *conn, gint fd,
if (ret == 1) {
conn->state = ssl_conn_connected;
+
+ if (event_get_base (ev)) {
+ event_del (ev);
+ }
+
event_set (ev, fd, EV_WRITE, rspamd_ssl_event_handler, conn);
if (conn->ev_base) {
@@ -480,6 +496,10 @@ rspamd_ssl_connect_fd (struct rspamd_ssl_connection *conn, gint fd,
return FALSE;
}
+ if (event_get_base (ev)) {
+ event_del (ev);
+ }
+
event_set (ev, fd, what, rspamd_ssl_event_handler, conn);
event_base_set (conn->ev_base, ev);
event_add (ev, tv);
@@ -546,6 +566,7 @@ rspamd_ssl_read (struct rspamd_ssl_connection *conn, gpointer buf,
return -1;
}
+ event_del (conn->ev);
event_set (conn->ev, conn->fd, what, rspamd_ssl_event_handler, conn);
event_base_set (conn->ev_base, conn->ev);
event_add (conn->ev, conn->tv);
@@ -615,6 +636,7 @@ rspamd_ssl_write (struct rspamd_ssl_connection *conn, gconstpointer buf,
return -1;
}
+ event_del (conn->ev);
event_set (conn->ev, conn->fd, what, rspamd_ssl_event_handler, conn);
event_base_set (conn->ev_base, conn->ev);
event_add (conn->ev, conn->tv);