]> jfr.im git - solanum.git/blobdiff - modules/m_away.c
CREDITS: Move mr_flea to committers section.
[solanum.git] / modules / m_away.c
index d8eb876409a1c26ea5fbc9c534239ec7ada9a1d7..9fba635d318d43443f65f911bdeddaa2840b49ff 100644 (file)
@@ -78,24 +78,36 @@ m_away(struct Client *client_p, struct Client *source_p, int parc, const char *p
        if(parc < 2 || EmptyString(parv[1]))
        {
                /* Marking as not away */
-               if(get_metadata(source_p, "away") != NULL)
+               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));
-                       delete_metadata(source_p, "away");
+                       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;
        }
 
-       set_metadata(source_p, "away", parv[1]);
-       sendto_server(client_p, NULL, CAP_TS6, NOCAPS, 
-                     ":%s AWAY :%s", use_id(source_p), parv[1]);
-                       
+       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);
+       }
+       
        if(MyConnect(source_p))
                sendto_one_numeric(source_p, RPL_NOWAWAY, form_str(RPL_NOWAWAY));
 
+       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);
+
        return 0;
 }