diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2003-01-23 19:45:57 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2003-01-23 19:45:57 +0000 |
commit | 73b9d0c5cb02f0ea8350de28bc3687e0af70ea0f (patch) | |
tree | a5845579b1363762650f0e45c62a13890e1efa43 /src/users.cpp |
Initial revision
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@132 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/users.cpp')
-rw-r--r-- | src/users.cpp | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/src/users.cpp b/src/users.cpp new file mode 100644 index 000000000..a6ced8231 --- /dev/null +++ b/src/users.cpp @@ -0,0 +1,92 @@ +/* + +$Log$ +Revision 1.1 2003/01/23 19:45:58 brain +Initial revision + +Revision 1.3 2003/01/17 13:21:38 brain +Added CONNECT ALLOW and CONNECT DENY config tags +Added PASS command + +Revision 1.2 2003/01/17 10:37:55 brain +Added /INVITE command and relevent structures + +Revision 1.1 2003/01/16 01:10:04 brain +forgot to add this + + +*/ + +#include "inspircd_config.h" +#include "channels.h" +#include "users.h" +#include "inspircd.h" +#include <stdio.h> + +userrec::userrec() +{ + // the PROPER way to do it, AVOID bzero at *ALL* costs + strcpy(nick,""); + ip = 0; + strcpy(ident,""); + strcpy(host,""); + strcpy(dhost,""); + strcpy(fullname,""); + strcpy(modes,""); + strcpy(inbuf,""); + strcpy(server,""); + strcpy(awaymsg,""); + fd = lastping = signon = idle_lastmsg = nping = registered = 0; + port = bytes_in = bytes_out = cmds_in = cmds_out = 0; + haspassed = false; + strcpy(result,""); + for (int i = 0; i < MAXCHANS; i++) + { + chans[i].channel = NULL; + } + invites.clear(); +} + + +char* userrec::GetFullHost() +{ + sprintf(result,"%s!%s@%s",nick,ident,dhost); + return result; +} + + +char* userrec::GetFullRealHost() +{ + sprintf(result,"%s!%s@%s",nick,ident,host); + return result; +} + +bool userrec::IsInvited(char* channel) +{ + for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) + { + if (!strcasecmp(i->channel,channel)) + { + return true; + } + } +} + +void userrec::InviteTo(char* channel) +{ + Invited i; + strcpy(i.channel,channel); + invites.push_back(i); +} + +void userrec::RemoveInvite(char* channel) +{ + for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) + { + if (!strcasecmp(i->channel,channel)) + { + invites.erase(i); + return; + } + } +} |