* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
*
- * $Id: ngircd.c,v 1.35 2002/03/25 19:11:01 alex Exp $
+ * $Id: ngircd.c,v 1.40 2002/03/29 23:34:18 alex Exp $
*
* ngircd.c: Hier beginnt alles ;-)
*/
GLOBAL int main( int argc, const char *argv[] )
{
- BOOLEAN ok;
+ BOOLEAN ok, configtest = FALSE;
INT32 pid, n;
INT i;
#ifdef SNIFFER
NGIRCd_Sniffer = FALSE;
#endif
+ strcpy( NGIRCd_ConfFile, CONFIG_FILE );
/* Kommandozeile parsen */
for( i = 1; i < argc; i++ )
{
/* Lange Option */
+ if( strcmp( argv[i], "--config" ) == 0 )
+ {
+ if( i + 1 < argc )
+ {
+ /* Ok, danach kommt noch ein Parameter */
+ strncpy( NGIRCd_ConfFile, argv[i + 1], FNAME_LEN - 1 );
+ NGIRCd_ConfFile[FNAME_LEN - 1] = '\0';
+
+ /* zum uebernaechsten Parameter */
+ i++; ok = TRUE;
+ }
+ }
+ if( strcmp( argv[i], "--configtest" ) == 0 )
+ {
+ configtest = TRUE;
+ ok = TRUE;
+ }
#ifdef DEBUG
if( strcmp( argv[i], "--debug" ) == 0 )
{
#endif
if( strcmp( argv[i], "--help" ) == 0 )
{
- Show_Version( ); puts( "" );
- Show_Help( ); puts( "" );
+ Show_Version( );
+ puts( "" ); Show_Help( ); puts( "" );
exit( 1 );
}
if( strcmp( argv[i], "--nodaemon" ) == 0 )
ok = TRUE;
}
#endif
+ if( argv[i][n] == 'f' )
+ {
+ if(( ! argv[i][n+i] ) && ( i + 1 < argc ))
+ {
+ /* Ok, danach kommt ein Leerzeichen */
+ strncpy( NGIRCd_ConfFile, argv[i + 1], FNAME_LEN - 1 );
+ NGIRCd_ConfFile[FNAME_LEN - 1] = '\0';
+
+ /* zum uebernaechsten Parameter */
+ i++; n = strlen( argv[i] );
+ ok = TRUE;
+ }
+ }
if( argv[i][n] == 'n' )
{
NGIRCd_NoDaemon = TRUE;
#ifdef SNIFFER
if( NGIRCd_Sniffer ) strcpy( NGIRCd_DebugLevel, "2" );
#endif
+
+ /* Soll nur die Konfigurations ueberprueft und ausgegeben werden? */
+ if( configtest )
+ {
+ Show_Version( ); puts( "" );
+ exit( Conf_Test( ));
+ }
while( ! NGIRCd_Quit )
{
Client_Init( );
Conn_Init( );
+ /* Wenn als root ausgefuehrt und eine andere UID
+ * konfiguriert ist, jetzt zu dieser wechseln */
+ if( getuid( ) == 0 )
+ {
+ if( Conf_GID != 0 )
+ {
+ /* Neue Group-ID setzen */
+ if( setgid( Conf_GID ) != 0 ) Log( LOG_ERR, "Can't change Group-ID to %u: %s", Conf_GID, strerror( errno ));
+ }
+ if( Conf_UID != 0 )
+ {
+ /* Neue User-ID setzen */
+ if( setuid( Conf_UID ) != 0 ) Log( LOG_ERR, "Can't change User-ID to %u: %s", Conf_UID, strerror( errno ));
+ }
+ }
+ Log( LOG_INFO, "Running as user %ld, group %ld.", (INT32)getuid( ), (INT32)getgid( ));
+
+ Log_InitErrorfile( );
+
/* Signal-Handler initialisieren */
Initialize_Signal_Handler( );
Log_Exit( );
}
-#ifndef DEBUG
- /* aufraeumen */
- if( unlink( ERROR_FILE ) != 0 ) Log( LOG_ERR, "Can't delete \""ERROR_FILE"\": %s", strerror( errno ));
-#endif
-
return 0;
} /* main */
/* Ports, auf denen der Server Verbindungen entgegennehmen
* soll, initialisieren */
- INT created, i;
+ UINT created, i;
created = 0;
for( i = 0; i < Conf_ListenPorts_Count; i++ )
{
if( Conn_NewListener( Conf_ListenPorts[i] )) created++;
- else Log( LOG_ERR, "Can't listen on port %d!", Conf_ListenPorts[i] );
+ else Log( LOG_ERR, "Can't listen on port %u!", Conf_ListenPorts[i] );
}
if( created < 1 )
LOCAL VOID Show_Help( VOID )
{
- puts( "Compile-time defaults:\n" );
- puts( " - configuration: "CONFIG_FILE );
- puts( " - MOTD file: "MOTD_FILE );
- puts( " - server error log: "ERROR_FILE"\n" );
- puts( "Run-time options:\n" );
#ifdef DEBUG
- puts( " -d, --debug log extra debug messages" );
+ puts( " -d, --debug log extra debug messages" );
#endif
- puts( " -n, --nodaemon don't fork and don't detatch from controlling terminal" );
- puts( " -p, --passive disable automatic connections to other servers" );
+ puts( " -f, --config <f> use file <f> as configuration file" );
+ puts( " -n, --nodaemon don't fork and don't detatch from controlling terminal" );
+ puts( " -p, --passive disable automatic connections to other servers" );
#ifdef SNIFFER
- puts( " -s, --sniffer enable network sniffer and display all IRC traffic" );
+ puts( " -s, --sniffer enable network sniffer and display all IRC traffic" );
#endif
- puts( " --version output version information and exit" );
- puts( " --help display this help and exit" );
+ puts( " --configtest read, validate and display configuration; then exit" );
+ puts( " --version output version information and exit" );
+ puts( " --help display this help and exit" );
} /* Show_Help */