]> jfr.im git - solanum.git/blobdiff - modules/m_away.c
Pace aways.
[solanum.git] / modules / m_away.c
index d52c66f42b0d8077536b6942e886540d809974bf..d7ca8fc75f4919e2190c199864a7758ac35a48d0 100644 (file)
@@ -37,7 +37,6 @@
 #include "s_serv.h"
 #include "packet.h"
 
-
 static int m_away(struct Client *, struct Client *, int, const char **);
 
 struct Message away_msgtab = {
@@ -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
@@ -85,26 +83,49 @@ m_away(struct Client *client_p, struct Client *source_p, int parc, const char *p
                        sendto_server(client_p, NULL, CAP_TS6, NOCAPS,
                                      ":%s AWAY", use_id(source_p));
                        free_away(source_p);
+
+                       sendto_common_channels_local_butone(source_p, CLICAP_AWAY_NOTIFY, ":%s!%s@%s AWAY",
+                                                           source_p->name, source_p->username, source_p->host);
                }
                if(MyConnect(source_p))
                        sendto_one_numeric(source_p, RPL_UNAWAY, form_str(RPL_UNAWAY));
                return 0;
        }
 
+       /* Rate limit this because it is sent to common channels. */
+       if(!IsOper(source_p) &&
+                       source_p->localClient->next_away > rb_current_time())
+       {
+               sendto_one(source_p, form_str(RPL_LOAD2HI),
+                               me.name, source_p->name, "AWAY");
+               return;
+       }
+       if(source_p->localClient->next_away < rb_current_time() -
+                       ConfigFileEntry.away_interval)
+               source_p->localClient->next_away = rb_current_time();
+       else
+               source_p->localClient->next_away = rb_current_time() +
+                       ConfigFileEntry.away_interval;
 
        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);
-                       
-       } else {
-               rb_strlcpy(source_p->user->away, parv[1], AWAYLEN);
+               sendto_common_channels_local_butone(source_p,
+                                                   CLICAP_AWAY_NOTIFY,
+                                                   ":%s!%s@%s AWAY :%s",
+                                                   source_p->name,
+                                                   source_p->username,
+                                                   source_p->host,
+                                                   source_p->user->away);
        }
        
        if(MyConnect(source_p))
                sendto_one_numeric(source_p, RPL_NOWAWAY, form_str(RPL_NOWAWAY));
 
+
        return 0;
 }