-/* Oper extban type: matches ssl users */
+/* SSL extban type: matches ssl users */
#include "stdinc.h"
#include "modules.h"
#include "client.h"
#include "ircd.h"
+static const char extb_desc[] = "SSL/TLS ($z) extban type";
+
static int _modinit(void);
static void _moddeinit(void);
static int eb_ssl(const char *data, struct Client *client_p, struct Channel *chptr, long mode_type);
-DECLARE_MODULE_AV1(extb_ssl, _modinit, _moddeinit, NULL, NULL, NULL, "$Revision$");
+DECLARE_MODULE_AV2(extb_ssl, _modinit, _moddeinit, NULL, NULL, NULL, NULL, NULL, extb_desc);
static int
_modinit(void)
(void)chptr;
(void)mode_type;
- /* perhaps use data somehow? (opernick/flags?) */
- /* so deny any bans with data for now */
+
+ if (! IsSSLClient(client_p))
+ return EXTBAN_NOMATCH;
+
if (data != NULL)
- return EXTBAN_INVALID;
- return IsSSLClient(client_p) ? EXTBAN_MATCH : EXTBAN_NOMATCH;
+ {
+ if (EmptyString(client_p->certfp))
+ return EXTBAN_NOMATCH;
+
+ if (irccmp(data, client_p->certfp) != 0)
+ return EXTBAN_NOMATCH;
+ }
+
+ return EXTBAN_MATCH;
}