X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/212380e3f42f585dc1ea927402252eb943f91f7b..55bb399f79289b68e9d25db15c60463502d4c2dc:/modules/m_away.c diff --git a/modules/m_away.c b/modules/m_away.c index 39db10a..02b510d 100644 --- a/modules/m_away.c +++ b/modules/m_away.c @@ -21,12 +21,12 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA * - * $Id: m_away.c 254 2005-09-21 23:35:12Z nenolod $ + * $Id: m_away.c 3370 2007-04-03 10:15:39Z nenolod $ */ #include "stdinc.h" #include "client.h" -#include "irc_string.h" +#include "match.h" #include "ircd.h" #include "numeric.h" #include "send.h" @@ -46,7 +46,7 @@ struct Message away_msgtab = { }; mapi_clist_av1 away_clist[] = { &away_msgtab, NULL }; -DECLARE_MODULE_AV1(away, NULL, NULL, away_clist, NULL, NULL, "$Revision: 254 $"); +DECLARE_MODULE_AV1(away, NULL, NULL, away_clist, NULL, NULL, "$Revision: 3370 $"); /*********************************************************************** * m_away() - Added 14 Dec 1988 by jto. @@ -64,78 +64,46 @@ DECLARE_MODULE_AV1(away, NULL, NULL, away_clist, NULL, NULL, "$Revision: 254 $") /* ** m_away -** parv[0] = sender prefix ** parv[1] = away message */ static int m_away(struct Client *client_p, struct Client *source_p, int parc, const char *parv[]) { - char *away; - char *awy2; - if(MyClient(source_p) && !IsFloodDone(source_p)) flood_endgrace(source_p); if(!IsClient(source_p)) return 0; - away = source_p->user->away; - if(parc < 2 || EmptyString(parv[1])) { /* Marking as not away */ - if(away) + if(source_p->user->away != NULL) { /* we now send this only if they were away before --is */ sendto_server(client_p, NULL, CAP_TS6, NOCAPS, ":%s AWAY", use_id(source_p)); - sendto_server(client_p, NULL, NOCAPS, CAP_TS6, - ":%s AWAY", source_p->name); - MyFree(away); - source_p->user->away = NULL; + free_away(source_p); } if(MyConnect(source_p)) - sendto_one(source_p, form_str(RPL_UNAWAY), - me.name, source_p->name); + sendto_one_numeric(source_p, RPL_UNAWAY, form_str(RPL_UNAWAY)); return 0; } - /* Marking as away */ - if(MyConnect(source_p)) - { - if(!IsOper(source_p) && - (CurrentTime - source_p->localClient->last_away) < ConfigFileEntry.pace_wait) - { - sendto_one(source_p, form_str(RPL_LOAD2HI), - me.name, source_p->name, "AWAY"); - return 0; - } - - source_p->localClient->last_away = CurrentTime; - } - - awy2 = LOCAL_COPY(parv[1]); - if(strlen(awy2) > AWAYLEN) - awy2[AWAYLEN] = '\0'; - - /* we now send this only if they weren't away already --is */ - if(!away) + if(source_p->user->away == NULL) { + allocate_away(source_p); + rb_strlcpy(source_p->user->away, parv[1], AWAYLEN); sendto_server(client_p, NULL, CAP_TS6, NOCAPS, - ":%s AWAY :%s", use_id(source_p), awy2); - sendto_server(client_p, NULL, NOCAPS, CAP_TS6, - ":%s AWAY :%s", source_p->name, awy2); + ":%s AWAY :%s", use_id(source_p), source_p->user->away); + + } else { + rb_strlcpy(source_p->user->away, parv[1], AWAYLEN); } - else - MyFree(away); - - DupString(away, awy2); - - source_p->user->away = away; - + if(MyConnect(source_p)) - sendto_one(source_p, form_str(RPL_NOWAWAY), me.name, source_p->name); + sendto_one_numeric(source_p, RPL_NOWAWAY, form_str(RPL_NOWAWAY)); return 0; }