0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-16 09:36:54 +01:00

opm: properly close listeners after disabling proxy scan

This commit is contained in:
Elizabeth Myers 2016-04-01 16:35:21 -05:00
parent 8275e2700d
commit 1661e3656d

View file

@ -438,6 +438,8 @@ opm_cancel(struct auth_client *auth)
{ {
rb_dlink_node *ptr, *nptr; rb_dlink_node *ptr, *nptr;
notice_client(auth->cid, "*** Did not detect open proxies");
RB_DLINK_FOREACH_SAFE(ptr, nptr, lookup->scans.head) RB_DLINK_FOREACH_SAFE(ptr, nptr, lookup->scans.head)
{ {
struct opm_scan *scan = ptr->data; struct opm_scan *scan = ptr->data;
@ -469,7 +471,25 @@ static void
set_opm_enabled(const char *key __unused, int parc __unused, const char **parv) set_opm_enabled(const char *key __unused, int parc __unused, const char **parv)
{ {
if(listeners[LISTEN_IPV4].F != NULL || listeners[LISTEN_IPV6].F != NULL) if(listeners[LISTEN_IPV4].F != NULL || listeners[LISTEN_IPV6].F != NULL)
opm_enable = (*parv[0] == '1'); {
if(!(opm_enable = (*parv[0] == '1')))
{
struct auth_client *auth;
rb_dictionary_iter iter;
/* Close the listening socket */
if(listeners[LISTEN_IPV4].F != NULL)
rb_close(listeners[LISTEN_IPV4].F);
if(listeners[LISTEN_IPV6].F != NULL)
rb_close(listeners[LISTEN_IPV6].F);
RB_DICTIONARY_FOREACH(auth, &iter, auth_clients)
{
opm_cancel(auth);
}
}
}
else else
/* No listener, no point... */ /* No listener, no point... */
opm_enable = false; opm_enable = false;