Implement user mode "c": receive connect/disconnect NOTICEs
Users having the user mode "c" set receive NOTICE messages on each new client connection to the local server as well as disconnects. Only IRC operators (users having the mode "o" set) are allowed to set the 'c' user mode. These connect/disconnect messages can be useful for open proxy scanners -- BOPM (http://wiki.blitzed.org/BOPM) is now functional with ngIRCd, for example.
This commit is contained in:
parent
51ed742054
commit
f76e0a1db6
|
@ -1136,6 +1136,9 @@ Destroy_UserOrService(CLIENT *Client, const char *Txt, const char *FwdMsg, bool
|
||||||
"%s \"%s\" unregistered (connection %d): %s",
|
"%s \"%s\" unregistered (connection %d): %s",
|
||||||
Client_TypeText(Client), Client_Mask(Client),
|
Client_TypeText(Client), Client_Mask(Client),
|
||||||
Client->conn_id, Txt);
|
Client->conn_id, Txt);
|
||||||
|
Log_ServerNotice('c', "Client exiting: %s (%s@%s) [%s]",
|
||||||
|
Client_ID(Client), Client_User(Client),
|
||||||
|
Client_Hostname(Client), Txt);
|
||||||
|
|
||||||
if (SendQuit) {
|
if (SendQuit) {
|
||||||
/* Inforam all the other servers */
|
/* Inforam all the other servers */
|
||||||
|
|
|
@ -80,7 +80,7 @@
|
||||||
#define RECONNECT_DELAY 3 /* Time to delay re-connect attempts
|
#define RECONNECT_DELAY 3 /* Time to delay re-connect attempts
|
||||||
in seconds. */
|
in seconds. */
|
||||||
|
|
||||||
#define USERMODES "aiorsw" /* Supported user modes. */
|
#define USERMODES "aciorsw" /* Supported user modes. */
|
||||||
#define CHANMODES "biIklmnoPstvz" /* Supported channel modes. */
|
#define CHANMODES "biIklmnoPstvz" /* Supported channel modes. */
|
||||||
|
|
||||||
#define CONNECTED true /* Internal status codes. */
|
#define CONNECTED true /* Internal status codes. */
|
||||||
|
|
|
@ -840,10 +840,16 @@ Introduce_Client(CLIENT *From, CLIENT *Client, int Type)
|
||||||
Client_Modes(Client), Client_ID(From),
|
Client_Modes(Client), Client_ID(From),
|
||||||
Client_ID(Client_Introducer(Client)),
|
Client_ID(Client_Introducer(Client)),
|
||||||
Client_Hops(Client), Client_Hops(Client) > 1 ? "s": "");
|
Client_Hops(Client), Client_Hops(Client) > 1 ? "s": "");
|
||||||
} else
|
} else {
|
||||||
Log(LOG_NOTICE, "%s \"%s\" registered (connection %d).",
|
Log(LOG_NOTICE, "%s \"%s\" registered (connection %d).",
|
||||||
Client_TypeText(Client), Client_Mask(Client),
|
Client_TypeText(Client), Client_Mask(Client),
|
||||||
Client_Conn(Client));
|
Client_Conn(Client));
|
||||||
|
Log_ServerNotice('c', "Client connecting: %s (%s@%s) [%s] - %s",
|
||||||
|
Client_ID(Client), Client_User(Client),
|
||||||
|
Client_Hostname(Client),
|
||||||
|
Conn_IPA(Client_Conn(Client)),
|
||||||
|
Client_TypeText(Client));
|
||||||
|
}
|
||||||
|
|
||||||
/* Inform other servers */
|
/* Inform other servers */
|
||||||
IRC_WriteStrServersPrefixFlag_CB(From,
|
IRC_WriteStrServersPrefixFlag_CB(From,
|
||||||
|
|
|
@ -172,6 +172,16 @@ Client_Mode( CLIENT *Client, REQUEST *Req, CLIENT *Origin, CLIENT *Target )
|
||||||
else ok = IRC_WriteStrClient( Origin, ERR_NOPRIVILEGES_MSG, Client_ID( Origin ));
|
else ok = IRC_WriteStrClient( Origin, ERR_NOPRIVILEGES_MSG, Client_ID( Origin ));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'c': /* Receive connect notices
|
||||||
|
* (only settable by IRC operators!) */
|
||||||
|
if(!set || Client_OperByMe(Origin)
|
||||||
|
|| Client_Type(Client) == CLIENT_SERVER)
|
||||||
|
x[0] = 'c';
|
||||||
|
else
|
||||||
|
ok = IRC_WriteStrClient(Origin,
|
||||||
|
ERR_NOPRIVILEGES_MSG,
|
||||||
|
Client_ID(Origin));
|
||||||
|
break;
|
||||||
case 'o': /* IRC operator (only unsettable!) */
|
case 'o': /* IRC operator (only unsettable!) */
|
||||||
if(( ! set ) || ( Client_Type( Client ) == CLIENT_SERVER ))
|
if(( ! set ) || ( Client_Type( Client ) == CLIENT_SERVER ))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue