From: Florian Westphal Date: Sun, 4 May 2008 13:07:21 +0000 (+0200) Subject: Invite: Send RPL_AWAY to client sending the invite if target is away. X-Git-Tag: rel-13-rc1~126 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3283d275ba26c470d131ce0b6f66ee54a00bfd1c;p=ngircd Invite: Send RPL_AWAY to client sending the invite if target is away. --- diff --git a/src/ngircd/irc-op.c b/src/ngircd/irc-op.c index 94b11beb..bbedcf4c 100644 --- a/src/ngircd/irc-op.c +++ b/src/ngircd/irc-op.c @@ -125,8 +125,14 @@ IRC_INVITE(CLIENT *Client, REQUEST *Req) if (Client_Conn(target) > NONE) { /* The target user is local, so we have to send the status code */ - if (!IRC_WriteStrClientPrefix(from, target, RPL_INVITING_MSG, Client_ID(from), Req->argv[0], Req->argv[1])) + if (!IRC_WriteStrClientPrefix(from, target, RPL_INVITING_MSG, + Client_ID(from), Req->argv[0], Req->argv[1])) return DISCONNECTED; + + if (strchr(Client_Modes(target), 'a') && + !IRC_WriteStrClient(from, RPL_AWAY_MSG, Client_ID(from), + Client_ID(target), Client_Away(target))) + return DISCONNECTED; } return CONNECTED; } /* IRC_INVITE */