listener: use exit_client instead of free_client
As well as leaking a connid and leaving the connection open, these calls to free_client() leave the client in the unknown_list causing check_unknowns_list() to crash when either ptr->data (ptr being the freed client_p->localClient->tnode) is NULL or when client_p->localClient is NULL. Flag the client as an IO error so that we don't try to send it any data (as this is not a normal plaintext connection).
This commit is contained in:
parent
785df805d7
commit
aaf6039eea
3 changed files with 23 additions and 22 deletions
|
@ -581,7 +581,6 @@ extern int is_remote_connect(struct Client *);
|
|||
extern void init_client(void);
|
||||
extern struct Client *make_client(struct Client *from);
|
||||
extern void free_pre_client(struct Client *client);
|
||||
extern void free_client(struct Client *client);
|
||||
|
||||
extern int exit_client(struct Client *, struct Client *, struct Client *, const char *);
|
||||
|
||||
|
|
|
@ -267,7 +267,7 @@ free_local_client(struct Client *client_p)
|
|||
client_p->localClient = NULL;
|
||||
}
|
||||
|
||||
void
|
||||
static void
|
||||
free_client(struct Client *client_p)
|
||||
{
|
||||
s_assert(NULL != client_p);
|
||||
|
|
|
@ -474,24 +474,7 @@ add_connection(struct Listener *listener, rb_fde_t *F, struct sockaddr *sai, str
|
|||
* the client has already been checked out in accept_connection
|
||||
*/
|
||||
new_client = make_client(NULL);
|
||||
|
||||
if (listener->ssl)
|
||||
{
|
||||
rb_fde_t *xF[2];
|
||||
if(rb_socketpair(AF_UNIX, SOCK_STREAM, 0, &xF[0], &xF[1], "Incoming ssld Connection") == -1)
|
||||
{
|
||||
free_client(new_client);
|
||||
return;
|
||||
}
|
||||
new_client->localClient->ssl_ctl = start_ssld_accept(F, xF[1], new_client->localClient->connid); /* this will close F for us */
|
||||
if(new_client->localClient->ssl_ctl == NULL)
|
||||
{
|
||||
free_client(new_client);
|
||||
return;
|
||||
}
|
||||
F = xF[0];
|
||||
SetSSL(new_client);
|
||||
}
|
||||
new_client->localClient->F = F;
|
||||
|
||||
memcpy(&new_client->localClient->ip, sai, sizeof(struct rb_sockaddr_storage));
|
||||
memcpy(&new_client->preClient->lip, lai, sizeof(struct rb_sockaddr_storage));
|
||||
|
@ -503,10 +486,29 @@ add_connection(struct Listener *listener, rb_fde_t *F, struct sockaddr *sai, str
|
|||
rb_inet_ntop_sock((struct sockaddr *)&new_client->localClient->ip, new_client->sockhost,
|
||||
sizeof(new_client->sockhost));
|
||||
|
||||
|
||||
rb_strlcpy(new_client->host, new_client->sockhost, sizeof(new_client->host));
|
||||
|
||||
if (listener->ssl)
|
||||
{
|
||||
rb_fde_t *xF[2];
|
||||
if(rb_socketpair(AF_UNIX, SOCK_STREAM, 0, &xF[0], &xF[1], "Incoming ssld Connection") == -1)
|
||||
{
|
||||
SetIOError(new_client);
|
||||
exit_client(new_client, new_client, new_client, "Fatal Error");
|
||||
return;
|
||||
}
|
||||
new_client->localClient->ssl_ctl = start_ssld_accept(F, xF[1], new_client->localClient->connid); /* this will close F for us */
|
||||
if(new_client->localClient->ssl_ctl == NULL)
|
||||
{
|
||||
SetIOError(new_client);
|
||||
exit_client(new_client, new_client, new_client, "Service Unavailable");
|
||||
return;
|
||||
}
|
||||
F = xF[0];
|
||||
new_client->localClient->F = F;
|
||||
SetSSL(new_client);
|
||||
}
|
||||
|
||||
new_client->localClient->listener = listener;
|
||||
|
||||
++listener->ref_count;
|
||||
|
|
Loading…
Reference in a new issue