((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);
/* 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);
+ 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 {
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);
}
char *ch;
char targetnick[NICKLEN+1];
int foundat;
- void *nargs[2];
+ void *nargs[3];
int i;
/* Should have target and message */
return CMD_OK;
}
- if (cargv[0][0]=='#' || cargv[0][0]=='+') {
- /* Channel message/notice */
- return CMD_OK;
- }
-
if ((sender=getnickbynumericstr((char *)source))==NULL) {
Error("localuser",ERR_WARNING,"PRIVMSG from non existant user %s",(char *)source);
return CMD_OK;
}
+
+ freesstring(sender->message);
+ sender->message = getsstring(cargv[1], 512);
+
+ nargs[0] = sender;
+ nargs[1] = cargv[1];
+ nargs[2] = (void *)(uintptr_t)isnotice;
+ triggerhook(HOOK_NICK_MESSAGE, nargs);
+
+ if (cargv[0][0]=='#' || cargv[0][0]=='+') {
+ /* Channel message/notice */
+ return CMD_OK;
+ }
/* Check for a "secure" message (foo@bar) */
foundat=0;