"*** Got Ident response",
"*** No Ident response",
"*** Cannot verify ident validity, ignoring ident",
+ "*** Ident disabled, not checking ident",
};
typedef enum
REPORT_FOUND,
REPORT_FAIL,
REPORT_INVALID,
+ REPORT_DISABLED,
} ident_message;
static EVH timeout_ident_queries_event;
static struct ev_entry *timeout_ev;
static int ident_timeout = 5;
+static bool ident_enable = true;
/* Timeout outstanding queries */
int family = GET_SS_FAMILY(&auth->c_addr);
if(auth->data[PROVIDER_IDENT] != NULL)
+ {
+ set_provider_done(auth, PROVIDER_IDENT); /* for blacklists */
return true;
+ }
+ else if(!ident_enable)
+ {
+ notice_client(auth->cid, messages[REPORT_DISABLED]);
+ set_provider_done(auth, PROVIDER_IDENT);
+ return true;
+ }
notice_client(auth->cid, messages[REPORT_LOOKUP]);
ident_timeout = timeout;
}
+static void
+set_ident_enabled(const char *key __unused, int parc __unused, const char **parv)
+{
+ ident_enable = (*parv[0] == '1');
+}
+
struct auth_opts_handler ident_options[] =
{
{ "ident_timeout", 1, add_conf_ident_timeout },
+ { "ident_enabled", 1, set_ident_enabled },
{ NULL, 0, NULL },
};