if(aconf->autojoin != NULL)
{
- user_join(client_p, source_p, aconf->autojoin, NULL, 0);
+ user_join(client_p, source_p, aconf->autojoin, NULL);
}
}
{
unsigned int old = source_p->umodes, oldsnomask = source_p->snomask;
hook_data_umode_changed hdata;
+ struct ConfItem *aconf;
SetOper(source_p);
sendto_one_notice(source_p, ":*** Oper privs are %s", oper_p->privset->privs);
send_oper_motd(source_p);
+ aconf = source_p->localClient->att_conf;
+
+ /* Do the auth::autojoin_opers wizardry here */
+ if(aconf->autojoin_opers != NULL)
+ {
+ /* opers should never be banned from the opers channel.
+ * 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(&me, source_p, aconf->autojoin_opers, NULL);
+ }
+
return (1);
}
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;