]> jfr.im git - irc/rqf/shadowircd.git/blobdiff - modules/m_away.c
Allow /ojoin !#channel/%#channel, if admin/halfop are enabled.
[irc/rqf/shadowircd.git] / modules / m_away.c
index 39db10a74203862b600df85dc898891efecb658f..02b510d8ed9caa1cbb6d396f7ff71d38c9081591 100644 (file)
  *  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;
 }