autochanmodes support
This commit is contained in:
parent
44a8fbc29e
commit
13ec57db15
|
@ -2,7 +2,6 @@ Todo list for Shadowircd 6.0
|
|||
-----------------------------
|
||||
* swhois support
|
||||
* custom operstrings (?)
|
||||
* autochanmodes defined in the .conf (cmodes that are set on a channel on initial join.)
|
||||
* halfops - probably enabled/disabled via a configure switch on in the .conf
|
||||
* owner/+a prefix/cmode - see comment for halfops :D
|
||||
* "soft" callerid umode (+G, only allows PM's from users in the same channel as you)
|
||||
|
|
|
@ -326,6 +326,7 @@ exempt {
|
|||
};
|
||||
|
||||
channel {
|
||||
autochanmodes = "nt";
|
||||
use_invex = yes;
|
||||
use_except = yes;
|
||||
use_knock = yes;
|
||||
|
|
|
@ -673,6 +673,11 @@ exempt {
|
|||
|
||||
/* The channel block contains options pertaining to channels */
|
||||
channel {
|
||||
/* autochanmodes: Modes that will be set on a unregistered channel
|
||||
* when the first user joins it.
|
||||
*/
|
||||
autochanmodes = "nt";
|
||||
|
||||
/* invex: Enable/disable channel mode +I, a n!u@h list of masks
|
||||
* that can join a +i channel without an invite.
|
||||
*/
|
||||
|
|
|
@ -222,6 +222,7 @@ struct config_file_entry
|
|||
|
||||
struct config_channel_entry
|
||||
{
|
||||
char * autochanmodes;
|
||||
int use_except;
|
||||
int use_invex;
|
||||
int use_knock;
|
||||
|
|
|
@ -332,6 +332,12 @@ static struct InfoStruct info_table[] = {
|
|||
&ServerInfo.network_desc,
|
||||
"Network description"
|
||||
},
|
||||
{
|
||||
"autochanmodes",
|
||||
OUTPUT_STRING,
|
||||
&ConfigChannel.autochanmodes,
|
||||
"Channelmodes set on channel creation"
|
||||
},
|
||||
{
|
||||
"nick_delay",
|
||||
OUTPUT_DECIMAL,
|
||||
|
|
|
@ -1679,8 +1679,22 @@ void user_join(struct Client * client_p, struct Client * source_p, const char *
|
|||
if(flags & CHFL_CHANOP)
|
||||
{
|
||||
chptr->channelts = rb_current_time();
|
||||
chptr->mode.mode |= MODE_TOPICLIMIT;
|
||||
chptr->mode.mode |= MODE_NOPRIVMSGS;
|
||||
|
||||
/* autochanmodes stuff */
|
||||
if(ConfigChannel.autochanmodes)
|
||||
{
|
||||
char * ch;
|
||||
for(ch = ConfigChannel.autochanmodes; *ch; *ch++)
|
||||
{
|
||||
chptr->mode.mode |= chmode_table[*ch].mode_type;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
chptr->mode.mode |= MODE_TOPICLIMIT;
|
||||
chptr->mode.mode |= MODE_NOPRIVMSGS;
|
||||
}
|
||||
|
||||
modes = channel_modes(chptr, &me);
|
||||
|
||||
sendto_channel_local(ONLY_CHANOPS, chptr, ":%s MODE %s %s",
|
||||
|
|
|
@ -2200,6 +2200,7 @@ static struct ConfEntry conf_general_table[] =
|
|||
|
||||
static struct ConfEntry conf_channel_table[] =
|
||||
{
|
||||
{ "autochanmodes", CF_QSTRING, NULL, 0, &ConfigChannel.autochanmodes },
|
||||
{ "default_split_user_count", CF_INT, NULL, 0, &ConfigChannel.default_split_user_count },
|
||||
{ "default_split_server_count", CF_INT, NULL, 0, &ConfigChannel.default_split_server_count },
|
||||
{ "burst_topicwho", CF_YESNO, NULL, 0, &ConfigChannel.burst_topicwho },
|
||||
|
|
|
@ -746,6 +746,7 @@ set_default_conf(void)
|
|||
ConfigFileEntry.oper_only_umodes = UMODE_SERVNOTICE;
|
||||
ConfigFileEntry.oper_snomask = SNO_GENERAL;
|
||||
|
||||
ConfigChannel.autochanmodes = rb_strdup("nt");
|
||||
ConfigChannel.use_except = YES;
|
||||
ConfigChannel.use_invex = YES;
|
||||
ConfigChannel.use_knock = YES;
|
||||
|
|
Loading…
Reference in New Issue