((unsigned char *)(ipaddress.in6_16))[14] = 1;
((unsigned char *)(ipaddress.in6_16))[15] = (currentlocalunum%253)+1;
+ memcpy(&newuser->ipaddress, &ipaddress, sizeof(ipaddress));
+
newuser->ipnode = refnode(iptree, &ipaddress, PATRICIA_MAXBITS);
node_increment_usercount(newuser->ipnode);
}
}
+ newuser->cloak_count = 0;
+ newuser->cloak_extra = NULL;
+
if (connected) {
/* Check for nick collision */
if ((np=getnickbynick(nickname))!=NULL) {
nick *np2;
char ipbuf[25];
time_t timestamp=getnettime();
-
+ void *harg[2];
+ char oldnick[NICKLEN+1];
+
if (!np)
return -1;
if (homeserver(np->numeric)!=mylongnum)
return -1;
+ strncpy(oldnick,np->nick,NICKLEN);
+ oldnick[NICKLEN]='\0';
+ harg[0]=(void *)np;
+ harg[1]=(void *)oldnick;
+
if ((np2=getnickbynick(newnick))) {
if (np2==np) {
/* Case only name change */
strncpy(np->nick,newnick,NICKLEN);
np->nick[NICKLEN]='\0';
- irc_send("%s N %s %jd",iptobase64(ipbuf, &(np->p_ipaddr), sizeof(ipbuf), 1),np->nick,(intmax_t)np->timestamp);
- triggerhook(HOOK_NICK_RENAME,np);
+ irc_send("%s N %s %jd",iptobase64(ipbuf, &(np->ipaddress), sizeof(ipbuf), 1),np->nick,(intmax_t)np->timestamp);
+ triggerhook(HOOK_NICK_RENAME,harg);
return 0;
} else {
/* Kill other user and drop through */
np->nick[NICKLEN]='\0';
addnicktohash(np);
irc_send("%s N %s %jd",longtonumeric(np->numeric,5),np->nick,(intmax_t)np->timestamp);
- triggerhook(HOOK_NICK_RENAME,np);
+ triggerhook(HOOK_NICK_RENAME,harg);
return 0;
}
irc_send("%s N %s 1 %ld %s %s %s%s%s %s %s :%s",
mynumeric->content,np->nick,np->timestamp,np->ident,np->host->name->content,
- printflags(np->umodes,umodeflags),operbuf,accountbuf,iptobase64(ipbuf,&(np->p_ipaddr),
+ printflags(np->umodes,umodeflags),operbuf,accountbuf,iptobase64(ipbuf,&(np->ipaddress),
sizeof(ipbuf),1),numericbuf,np->realname->name->content);
}
triggerhook(HOOK_AUTH_FLAGSUPDATED, arg);
}
+
+void localuseraddcloaktarget(nick *np, nick *target) {
+ char snumeric[10], tnumeric[10];
+
+ strcpy(snumeric, longtonumeric(np->numeric,5));
+ strcpy(tnumeric, longtonumeric(target->numeric,5));
+
+ irc_send("%s CA %s", snumeric, tnumeric);
+
+ addcloaktarget(np, target);
+}
+
+void localuserclearcloaktargets(nick *np) {
+ irc_send("%s CU", longtonumeric(np->numeric,5));
+ clearcloaktargets(np);
+}
+