/*
** m_away
-** parv[0] = sender prefix
** parv[1] = away message
*/
static int
if(parc < 2 || EmptyString(parv[1]))
{
/* Marking as not away */
- if(source_p->user->away != NULL)
+ if(get_metadata(source_p, "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);
- free_away(source_p);
+ delete_metadata(source_p, "away");
}
if(MyConnect(source_p))
sendto_one_numeric(source_p, RPL_UNAWAY, form_str(RPL_UNAWAY));
return 0;
}
-
- 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), source_p->user->away);
- sendto_server(client_p, NULL, NOCAPS, CAP_TS6,
- ":%s AWAY :%s", source_p->name, source_p->user->away);
+ set_metadata(source_p, "away", parv[1]);
+ sendto_server(client_p, NULL, CAP_TS6, NOCAPS,
+ ":%s AWAY :%s", use_id(source_p), parv[1]);
- } else {
- rb_strlcpy(source_p->user->away, parv[1], AWAYLEN);
- }
-
if(MyConnect(source_p))
sendto_one_numeric(source_p, RPL_NOWAWAY, form_str(RPL_NOWAWAY));