6cfb19943a
I had the idea that maybe these should be case-sensitive because some encodings (like Base-64) are. But it turns out it's better to prioritise not breaking existing configurations / channel mode lists, and just revisit this in future maybe. [ci skip]
50 lines
946 B
C
50 lines
946 B
C
/* 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_AV2(extb_ssl, _modinit, _moddeinit, NULL, NULL, NULL, NULL, NULL, extb_desc);
|
|
|
|
static int
|
|
_modinit(void)
|
|
{
|
|
extban_table['z'] = eb_ssl;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
_moddeinit(void)
|
|
{
|
|
extban_table['z'] = NULL;
|
|
}
|
|
|
|
static int eb_ssl(const char *data, struct Client *client_p,
|
|
struct Channel *chptr, long mode_type)
|
|
{
|
|
|
|
(void)chptr;
|
|
(void)mode_type;
|
|
|
|
if (! IsSSLClient(client_p))
|
|
return EXTBAN_NOMATCH;
|
|
|
|
if (data != NULL)
|
|
{
|
|
if (EmptyString(client_p->certfp))
|
|
return EXTBAN_NOMATCH;
|
|
|
|
if (irccmp(data, client_p->certfp) != 0)
|
|
return EXTBAN_NOMATCH;
|
|
}
|
|
|
|
return EXTBAN_MATCH;
|
|
}
|