* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
*
- * $Id: conn.c,v 1.33 2002/01/06 15:18:14 alex Exp $
+ * $Id: conn.c,v 1.38 2002/02/19 20:34:31 alex Exp $
*
* connect.h: Verwaltung aller Netz-Verbindungen ("connections")
*
* $Log: conn.c,v $
+ * Revision 1.38 2002/02/19 20:34:31 alex
+ * - Bei ausgehenden Verbindungen wird der Ziel-Port ins Log geschrieben.
+ *
+ * Revision 1.37 2002/02/19 20:05:37 alex
+ * - "Passive-Mode" implementiert: kein Auto-Conect zu anderen Servern.
+ *
+ * Revision 1.36 2002/02/11 01:00:50 alex
+ * - neue Funktion Conn_LastPing().
+ *
+ * Revision 1.35 2002/01/18 11:12:11 alex
+ * - der Sniffer wird nun nur noch aktiviert, wenn auf Kommandozeile angegeben.
+ *
+ * Revision 1.34 2002/01/07 15:29:52 alex
+ * - PASSSERVERADD definiert, wird beim PASS-Befehl an Server verwendet.
+ *
* Revision 1.33 2002/01/06 15:18:14 alex
* - Loglevel und Meldungen nochmals geaendert. Level passen nun besser.
*
}
#ifdef SNIFFER
- Log( LOG_DEBUG, " -> connection %d: '%s'.", Idx, buffer );
+ if( NGIRCd_Sniffer ) Log( LOG_DEBUG, " -> connection %d: '%s'.", Idx, buffer );
#endif
strcat( buffer, "\r\n" );
} /* Conn_GetIdle */
+GLOBAL INT32 Conn_LastPing( CONN_ID Idx )
+{
+ /* Zeitpunkt des letzten PING liefern */
+
+ assert( Idx >= 0 );
+ return My_Connections[Idx].lastping;
+} /* Conn_LastPing */
+
+
LOCAL BOOLEAN Try_Write( CONN_ID Idx )
{
/* Versuchen, Daten aus dem Schreib-Puffer in den
INT idx, i, n;
RES_STAT *s;
+
+ /* Wenn "Passive-Mode" aktiv: nicht verbinden */
+ if( NGIRCd_Passive ) return;
for( i = 0; i < Conf_Server_Count; i++ )
{
return;
}
- Log( LOG_INFO, "Establishing connection to \"%s\", %s (connection %d) ... ", Conf_Server[Server].host, Conf_Server[Server].ip, Idx );
+ Log( LOG_INFO, "Establishing connection to \"%s\", %s, port %d (connection %d) ... ", Conf_Server[Server].host, Conf_Server[Server].ip, Conf_Server[Server].port, Idx );
if( inet_aton( Conf_Server[Server].ip, &inaddr ) == 0 )
{
if( new_sock > My_Max_Fd ) My_Max_Fd = new_sock;
/* PASS und SERVER verschicken */
- Conn_WriteStr( Idx, "PASS %s "PROTOVER""PROTOSUFFIX" IRC|"PACKAGE"-"VERSION" P", Conf_Server[Server].pwd );
+ Conn_WriteStr( Idx, "PASS %s "PASSSERVERADD, Conf_Server[Server].pwd );
Conn_WriteStr( Idx, "SERVER %s :%s", Conf_ServerName, Conf_ServerInfo );
} /* New_Server */