2016-01-30 03:26:41 +00:00
|
|
|
#include "stdinc.h"
|
|
|
|
#include "modules.h"
|
|
|
|
#include "hook.h"
|
|
|
|
#include "client.h"
|
|
|
|
#include "ircd.h"
|
|
|
|
#include "send.h"
|
|
|
|
#include "s_conf.h"
|
|
|
|
#include "s_user.h"
|
|
|
|
#include "s_serv.h"
|
|
|
|
#include "numeric.h"
|
|
|
|
#include "chmode.h"
|
|
|
|
|
2016-03-07 05:48:27 +00:00
|
|
|
static const char chm_insecure_desc[] =
|
|
|
|
"Adds channel mode +U that allows non-SSL users to join a channel, "
|
|
|
|
"disallowing them by default";
|
2016-01-30 03:26:41 +00:00
|
|
|
|
2016-03-09 07:29:41 +00:00
|
|
|
static void h_can_join(hook_data_channel *);
|
|
|
|
|
2016-01-30 03:26:41 +00:00
|
|
|
mapi_hfn_list_av1 sslonly_hfnlist[] = {
|
|
|
|
{ "can_join", (hookfn) h_can_join },
|
|
|
|
{ NULL, NULL }
|
|
|
|
};
|
|
|
|
|
|
|
|
static unsigned int mymode;
|
|
|
|
|
|
|
|
static int
|
|
|
|
_modinit(void)
|
|
|
|
{
|
|
|
|
mymode = cflag_add('U', chm_simple);
|
|
|
|
if (mymode == 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
_moddeinit(void)
|
|
|
|
{
|
|
|
|
cflag_orphan('U');
|
|
|
|
}
|
|
|
|
|
2016-03-07 05:48:27 +00:00
|
|
|
DECLARE_MODULE_AV2(chm_insecure, _modinit, _moddeinit, NULL, NULL, sslonly_hfnlist, NULL, NULL, chm_insecure_desc);
|
2016-01-30 03:26:41 +00:00
|
|
|
|
|
|
|
static void
|
|
|
|
h_can_join(hook_data_channel *data)
|
|
|
|
{
|
|
|
|
struct Client *source_p = data->client;
|
|
|
|
struct Channel *chptr = data->chptr;
|
|
|
|
|
2020-10-28 21:55:26 +00:00
|
|
|
if(!(chptr->mode.mode & mymode) && !IsSecureClient(source_p)) {
|
2016-01-30 03:26:41 +00:00
|
|
|
/* XXX This is equal to ERR_THROTTLE */
|
|
|
|
sendto_one_numeric(source_p, 480, "%s :Cannot join channel (-U) - SSL/TLS required", chptr->chname);
|
|
|
|
data->approved = ERR_CUSTOM;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|