1
0
mirror of https://github.com/osmarks/ngircd.git synced 2025-01-07 14:20:29 +00:00

Add new IRC+ server flag "X": "XOP modes supported"

This flag indicates, that the server supports the enhanced "xop channel
user modes", like channel owner, admin, and halfop. This information is
used to make sure that no unsupported CHANINFO commands are sent to
servers not supporting such mode prefixes, for example.
This commit is contained in:
Alexander Barton 2012-11-10 23:33:19 +01:00
parent 646218e6f4
commit 53917fa4b8
3 changed files with 13 additions and 9 deletions

View File

@ -89,6 +89,9 @@ The following <serverflags> are defined at the moment:
- S: The server supports the SERVICE command (on this link). - S: The server supports the SERVICE command (on this link).
- X: Server supports XOP channel modes (owner, admin, halfop) and supports
these user prefixes in CHANINFO commands, for example.
- Z: Compressed server links are supported by the server. - Z: Compressed server links are supported by the server.
Example for a complete <flags> string: "ngircd|0.7.5:CZ". Example for a complete <flags> string: "ngircd|0.7.5:CZ".

View File

@ -157,7 +157,7 @@
#ifdef IRCPLUS #ifdef IRCPLUS
/** Standard IRC+ flags. */ /** Standard IRC+ flags. */
# define IRCPLUSFLAGS "CHLMS" # define IRCPLUSFLAGS "CHLMSX"
#endif #endif
/** Supported user modes. */ /** Supported user modes. */

View File

@ -48,12 +48,11 @@ Announce_Channel(CLIENT *Client, CHANNEL *Chan)
CL2CHAN *cl2chan; CL2CHAN *cl2chan;
CLIENT *cl; CLIENT *cl;
char str[LINE_LEN], *ptr; char str[LINE_LEN], *ptr;
bool njoin; bool njoin, xop;
if (Conn_Options(Client_Conn(Client)) & CONN_RFC1459) /* Check features of remote server */
njoin = false; njoin = Conn_Options(Client_Conn(Client)) & CONN_RFC1459 ? false : true;
else xop = strchr(Client_Flags(Client), 'X') ? true : false;
njoin = true;
/* Get all the members of this channel */ /* Get all the members of this channel */
cl2chan = Channel_FirstMember(Chan); cl2chan = Channel_FirstMember(Chan);
@ -67,13 +66,15 @@ Announce_Channel(CLIENT *Client, CHANNEL *Chan)
* (if user is channel operator or has voice) */ * (if user is channel operator or has voice) */
if (str[strlen(str) - 1] != ':') if (str[strlen(str) - 1] != ':')
strlcat(str, ",", sizeof(str)); strlcat(str, ",", sizeof(str));
if (strchr(Channel_UserModes(Chan, cl), 'q'))
/* Prepare user prefix (ChanOp, voiced, ...) */
if (xop && strchr(Channel_UserModes(Chan, cl), 'q'))
strlcat(str, "~", sizeof(str)); strlcat(str, "~", sizeof(str));
if (strchr(Channel_UserModes(Chan, cl), 'a')) if (xop && strchr(Channel_UserModes(Chan, cl), 'a'))
strlcat(str, "&", sizeof(str)); strlcat(str, "&", sizeof(str));
if (strchr(Channel_UserModes(Chan, cl), 'o')) if (strchr(Channel_UserModes(Chan, cl), 'o'))
strlcat(str, "@", sizeof(str)); strlcat(str, "@", sizeof(str));
if (strchr(Channel_UserModes(Chan, cl), 'h')) if (xop && strchr(Channel_UserModes(Chan, cl), 'h'))
strlcat(str, "%", sizeof(str)); strlcat(str, "%", sizeof(str));
if (strchr(Channel_UserModes(Chan, cl), 'v')) if (strchr(Channel_UserModes(Chan, cl), 'v'))
strlcat(str, "+", sizeof(str)); strlcat(str, "+", sizeof(str));