}
/*
- * 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;
- memcpy(&newuser->ipaddress, &ipaddress, sizeof(ipaddress));
+ 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);
+ newuser->ipnode = refnode(iptree, ipaddress, PATRICIA_MAXBITS);
node_increment_usercount(newuser->ipnode);
newuser->timestamp=getnettime();
newuser->cloak_count = 0;
newuser->cloak_extra = NULL;
+ newuser->message = NULL;
if (connected) {
/* Check for nick collision */
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;