X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/87f58b4ffb83489c7c05af936863126c8afd9ddf..2b3c7c29c334c3ebb6a2da2176d89a65f5ad9ffa:/src/s_user.c diff --git a/src/s_user.c b/src/s_user.c index 23c569b..8c9683e 100644 --- a/src/s_user.c +++ b/src/s_user.c @@ -109,7 +109,7 @@ int user_modes[256] = { 0, /* m */ 0, /* n */ UMODE_OPER, /* o */ - 0, /* p */ + UMODE_OVERRIDE, /* p */ 0, /* q */ 0, /* r */ UMODE_SERVNOTICE, /* s */ @@ -711,7 +711,7 @@ introduce_client(struct Client *client_p, struct Client *source_p, struct User * if(aconf->autojoin != NULL) { - user_join(client_p, source_p, aconf->autojoin, NULL, 0); + user_join(client_p, source_p, aconf->autojoin, NULL); } } @@ -881,6 +881,15 @@ report_and_set_user_flags(struct Client *source_p, struct ConfItem *aconf) } } +static void +expire_umode_p(void *data) +{ + struct Client *source_p = data; + char *parv[4] = {source_p->name, source_p->name, "-p", NULL}; + source_p->localClient->override_timeout_event = NULL; + user_mode(source_p, source_p, 3, parv); +} + static void show_other_user_mode(struct Client *source_p, struct Client *target_p) { @@ -1138,6 +1147,12 @@ user_mode(struct Client *client_p, struct Client *source_p, int parc, const char source_p->umodes &= ~UMODE_ADMIN; } + if(MyConnect(source_p) && (source_p->umodes & UMODE_OVERRIDE) && (!IsOperOverride(source_p))) + { + sendto_one_notice(source_p, ":*** You need oper and the override flag for +p"); + source_p->umodes &= ~UMODE_OVERRIDE; + } + /* let modules providing usermodes know that we've changed our usermode --nenolod */ hdata.client = source_p; hdata.oldumodes = setflags; @@ -1157,6 +1172,17 @@ user_mode(struct Client *client_p, struct Client *source_p, int parc, const char sendto_one_numeric(source_p, RPL_SNOMASK, form_str(RPL_SNOMASK), construct_snobuf(source_p->snomask)); + if(ConfigFileEntry.expire_override_time && MyClient(source_p) && (source_p->umodes & ~setflags) & UMODE_OVERRIDE) + { + source_p->localClient->override_timeout_event = + rb_event_addonce("expire_override", expire_umode_p, source_p, ConfigFileEntry.expire_override_time); + } + else if(MyClient(source_p) && source_p->localClient->override_timeout_event && (setflags & ~source_p->umodes) & UMODE_OVERRIDE) + { + rb_event_delete(source_p->localClient->override_timeout_event); + source_p->localClient->override_timeout_event = NULL; + } + return (0); } @@ -1364,7 +1390,7 @@ oper_up(struct Client *source_p, struct oper_conf *oper_p) * Plus this is post-umode being set so you'll pass +I $o or +O. * Hence why we're making this a normal clean join. --jdhore */ - user_join(client_p, source_p, aconf->autojoin_opers, NULL, 0); + user_join(&me, source_p, aconf->autojoin_opers, NULL); } return (1); @@ -1435,7 +1461,7 @@ change_nick_user_host(struct Client *target_p, const char *nick, const char *use struct membership *mscptr; int changed = irccmp(target_p->name, nick); int changed_case = strcmp(target_p->name, nick); - int do_qjm = irccmp(target_p->username, user) || irccmp(target_p->host, host); + int do_qjm = irccmp(target_p->username, user) || (irccmp(target_p->host, host) && ConfigChannel.cycle_host_change); char mode[10], modeval[NICKLEN * 2 + 2], reason[256], *mptr; va_list ap;