}
/*
- * registerlocaluserflags:
+ * registerlocaluserflagsip:
* This function creates a local user, and broadcasts it's existence to the net (if connected).
*/
-nick *registerlocaluserflags(char *nickname, char *ident, char *host, char *realname, char *authname, unsigned long authid, flag_t accountflags, flag_t umodes, UserMessageHandler handler) {
+nick *registerlocaluserflagsip(char *nickname, char *ident, char *host, char *realname, char *authname, unsigned long authid, flag_t accountflags, flag_t umodes, struct irc_in_addr *ipaddress, UserMessageHandler handler) {
int i;
nick *newuser,*np;
- struct irc_in_addr ipaddress;
+ struct irc_in_addr tmpipaddress;
i=0;
currentlocalunum=(currentlocalunum+1)%262142;
newuser->realname->nicks=newuser;
newuser->umodes=umodes;
- memset(&ipaddress, 0, sizeof(ipaddress));
- ((unsigned short *)(ipaddress.in6_16))[5] = 65535;
- ((unsigned short *)(ipaddress.in6_16))[6] = 127;
- ((unsigned char *)(ipaddress.in6_16))[14] = 1;
- ((unsigned char *)(ipaddress.in6_16))[15] = (currentlocalunum%253)+1;
+ if (!ipaddress) {
+ ipaddress = &tmpipaddress;
- newuser->ipnode = refnode(iptree, &ipaddress, PATRICIA_MAXBITS);
+ memset(ipaddress, 0, sizeof(struct irc_in_addr));
+ ((unsigned short *)(ipaddress->in6_16))[5] = 65535;
+ ((unsigned short *)(ipaddress->in6_16))[6] = 127;
+ ((unsigned char *)(ipaddress->in6_16))[14] = 1;
+ ((unsigned char *)(ipaddress->in6_16))[15] = (currentlocalunum%253)+1;
+ }
+
+ memcpy(&newuser->ipaddress, ipaddress, sizeof(struct irc_in_addr));
+
+ newuser->ipnode = refnode(iptree, ipaddress, PATRICIA_MAXBITS);
node_increment_usercount(newuser->ipnode);
newuser->timestamp=getnettime();
newuser->shident=NULL;
newuser->sethost=NULL;
+ newuser->away=NULL;
newuser->marker=0;
memset(newuser->exts, 0, MAXNICKEXTS * sizeof(void *));
}
}
+ newuser->cloak_count = 0;
+ newuser->cloak_extra = NULL;
+ newuser->message = 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 %d",iptobase64(ipbuf, &(np->p_ipaddr), sizeof(ipbuf), 1),np->nick,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 */
strncpy(np->nick,newnick,NICKLEN);
np->nick[NICKLEN]='\0';
addnicktohash(np);
- irc_send("%s N %s %d",longtonumeric(np->numeric,5),np->nick,np->timestamp);
- triggerhook(HOOK_NICK_RENAME,np);
+ irc_send("%s N %s %jd",longtonumeric(np->numeric,5),np->nick,(intmax_t)np->timestamp);
+ 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);
}
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;
void _killuser(nick *source, nick *target, char *reason) {
char senderstr[6];
char sourcestring[HOSTLEN+NICKLEN+3];
+ char reasonstr[512];
+ void *args[2];
if (!source) {
/* If we have a null nick, use the server.. */
sprintf(sourcestring,"%s!%s",source->host->name->content, source->nick);
}
- irc_send("%s D %s :%s (%s)",senderstr,longtonumeric(target->numeric,5),sourcestring,reason);
+ snprintf(reasonstr,512,"%s (%s)",sourcestring,reason);
+ reasonstr[511]='\0';
+
+ irc_send("%s D %s :%s",senderstr,longtonumeric(target->numeric,5),reasonstr);
+
+ args[0]=target;
+ args[1]=reasonstr;
+ triggerhook(HOOK_NICK_KILL, args);
+
deletenick(target);
}
}
void sendaccountmessage(nick *np) {
- if (connected) {
+ if (connected && IsAccount(np)) {
if (np->auth) {
if (np->auth->flags) {
irc_send("%s AC %s %s %ld %lu %"PRIu64,mynumeric->content, longtonumeric(np->numeric,5), np->authname, np->accountts, np->auth->userid, np->auth->flags);
arg[1] = &oldflags;
anp->flags = accountflags;
- for(np=anp->nicks;np;np=np->next)
+ for(np=anp->nicks;np;np=np->nextbyauthname)
sendaccountmessage(np);
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);
+}
+