]> jfr.im git - irc/rqf/shadowircd.git/blobdiff - modules/m_away.c
mkpasswd: Default to SHA512 instead of inherently insecure DES.
[irc/rqf/shadowircd.git] / modules / m_away.c
index cd4c89bdb4d1e79e4aacd59d5bc6a0ffc8c0bd98..557371ecb04f069da729b8416c8100e3182350db 100644 (file)
@@ -21,7 +21,6 @@
  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
  *  USA
  *
- *  $Id: m_away.c 3370 2007-04-03 10:15:39Z nenolod $
  */
 
 #include "stdinc.h"
@@ -64,7 +63,6 @@ DECLARE_MODULE_AV1(away, NULL, NULL, away_clist, NULL, NULL, "$Revision: 3370 $"
 
 /*
 ** m_away
-**      parv[0] = sender prefix
 **      parv[1] = away message
 */
 static int
@@ -84,32 +82,24 @@ m_away(struct Client *client_p, struct Client *source_p, int parc, const char *p
                        /* 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);
                        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;
        }
 
-
        if(source_p->user->away == NULL)
-       {
                allocate_away(source_p);
+       if(strncmp(source_p->user->away, parv[1], AWAYLEN - 1))
+       {
                rb_strlcpy(source_p->user->away, parv[1], AWAYLEN);
                sendto_server(client_p, NULL, CAP_TS6, NOCAPS, 
                              ":%s AWAY :%s", use_id(source_p), source_p->user->away);
-               sendto_server(client_p, NULL, NOCAPS, CAP_TS6,
-                             ":%s AWAY :%s", source_p->name, source_p->user->away);
-                       
-       } else {
-               rb_strlcpy(source_p->user->away, parv[1], AWAYLEN);
        }
        
        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;
 }