mirror of
https://github.com/osmarks/ngircd.git
synced 2025-03-12 20:18:11 +00:00
- Backport aus HEAD: UID und GID kann nun auch textuell angegeben werden.
This commit is contained in:
parent
266b68b873
commit
6cdc8f7802
@ -9,7 +9,7 @@
|
|||||||
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
||||||
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
||||||
*
|
*
|
||||||
* $Id: conf.c,v 1.29.2.4 2002/11/04 19:18:39 alex Exp $
|
* $Id: conf.c,v 1.29.2.5 2002/11/24 15:25:25 alex Exp $
|
||||||
*
|
*
|
||||||
* conf.h: Konfiguration des ngircd
|
* conf.h: Konfiguration des ngircd
|
||||||
*/
|
*/
|
||||||
@ -25,6 +25,9 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <pwd.h>
|
||||||
|
#include <grp.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
#include "ngircd.h"
|
#include "ngircd.h"
|
||||||
#include "conn.h"
|
#include "conn.h"
|
||||||
@ -67,6 +70,8 @@ Conf_Test( VOID )
|
|||||||
{
|
{
|
||||||
/* Konfiguration einlesen, ueberpruefen und ausgeben. */
|
/* Konfiguration einlesen, ueberpruefen und ausgeben. */
|
||||||
|
|
||||||
|
struct passwd *pwd;
|
||||||
|
struct group *grp;
|
||||||
INT i;
|
INT i;
|
||||||
|
|
||||||
Use_Log = FALSE;
|
Use_Log = FALSE;
|
||||||
@ -91,15 +96,19 @@ Conf_Test( VOID )
|
|||||||
printf( " AdminInfo2 = %s\n", Conf_ServerAdmin2 );
|
printf( " AdminInfo2 = %s\n", Conf_ServerAdmin2 );
|
||||||
printf( " AdminEMail = %s\n", Conf_ServerAdminMail );
|
printf( " AdminEMail = %s\n", Conf_ServerAdminMail );
|
||||||
printf( " MotdFile = %s\n", Conf_MotdFile );
|
printf( " MotdFile = %s\n", Conf_MotdFile );
|
||||||
printf( " ListenPorts = " );
|
printf( " Ports = " );
|
||||||
for( i = 0; i < Conf_ListenPorts_Count; i++ )
|
for( i = 0; i < Conf_ListenPorts_Count; i++ )
|
||||||
{
|
{
|
||||||
if( i != 0 ) printf( ", " );
|
if( i != 0 ) printf( ", " );
|
||||||
printf( "%u", Conf_ListenPorts[i] );
|
printf( "%u", Conf_ListenPorts[i] );
|
||||||
}
|
}
|
||||||
puts( "" );
|
puts( "" );
|
||||||
printf( " ServerUID = %ld\n", (LONG)Conf_UID );
|
pwd = getpwuid( Conf_UID );
|
||||||
printf( " ServerGID = %ld\n", (LONG)Conf_GID );
|
if( pwd ) printf( " ServerUID = %s\n", pwd->pw_name );
|
||||||
|
else printf( " ServerUID = %ld\n", (LONG)Conf_UID );
|
||||||
|
grp = getgrgid( Conf_GID );
|
||||||
|
if( grp ) printf( " ServerGID = %s\n", grp->gr_name );
|
||||||
|
else printf( " ServerGID = %ld\n", (LONG)Conf_GID );
|
||||||
printf( " PingTimeout = %d\n", Conf_PingTimeout );
|
printf( " PingTimeout = %d\n", Conf_PingTimeout );
|
||||||
printf( " PongTimeout = %d\n", Conf_PongTimeout );
|
printf( " PongTimeout = %d\n", Conf_PongTimeout );
|
||||||
printf( " ConnectRetry = %d\n", Conf_ConnectRetry );
|
printf( " ConnectRetry = %d\n", Conf_ConnectRetry );
|
||||||
@ -294,6 +303,8 @@ Read_Config( VOID )
|
|||||||
LOCAL VOID
|
LOCAL VOID
|
||||||
Handle_GLOBAL( INT Line, CHAR *Var, CHAR *Arg )
|
Handle_GLOBAL( INT Line, CHAR *Var, CHAR *Arg )
|
||||||
{
|
{
|
||||||
|
struct passwd *pwd;
|
||||||
|
struct group *grp;
|
||||||
CHAR *ptr;
|
CHAR *ptr;
|
||||||
LONG port;
|
LONG port;
|
||||||
|
|
||||||
@ -372,13 +383,17 @@ Handle_GLOBAL( INT Line, CHAR *Var, CHAR *Arg )
|
|||||||
if( strcasecmp( Var, "ServerUID" ) == 0 )
|
if( strcasecmp( Var, "ServerUID" ) == 0 )
|
||||||
{
|
{
|
||||||
/* UID, mit der der Daemon laufen soll */
|
/* UID, mit der der Daemon laufen soll */
|
||||||
Conf_UID = (UINT)atoi( Arg );
|
pwd = getpwnam( Arg );
|
||||||
|
if( pwd ) Conf_UID = pwd->pw_uid;
|
||||||
|
else Conf_UID = (UINT)atoi( Arg );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if( strcasecmp( Var, "ServerGID" ) == 0 )
|
if( strcasecmp( Var, "ServerGID" ) == 0 )
|
||||||
{
|
{
|
||||||
/* GID, mit der der Daemon laufen soll */
|
/* GID, mit der der Daemon laufen soll */
|
||||||
Conf_GID = (UINT)atoi( Arg );
|
grp = getgrnam( Arg );
|
||||||
|
if( grp ) Conf_GID = grp->gr_gid;
|
||||||
|
else Conf_GID = (UINT)atoi( Arg );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if( strcasecmp( Var, "PingTimeout" ) == 0 )
|
if( strcasecmp( Var, "PingTimeout" ) == 0 )
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
||||||
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
||||||
*
|
*
|
||||||
* $Id: ngircd.c,v 1.54.2.3 2002/11/04 19:18:39 alex Exp $
|
* $Id: ngircd.c,v 1.54.2.4 2002/11/24 15:25:25 alex Exp $
|
||||||
*
|
*
|
||||||
* ngircd.c: Hier beginnt alles ;-)
|
* ngircd.c: Hier beginnt alles ;-)
|
||||||
*/
|
*/
|
||||||
@ -29,6 +29,8 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#include <pwd.h>
|
||||||
|
#include <grp.h>
|
||||||
|
|
||||||
#include "resolve.h"
|
#include "resolve.h"
|
||||||
#include "conn.h"
|
#include "conn.h"
|
||||||
@ -57,6 +59,8 @@ LOCAL VOID Show_Help PARAMS(( VOID ));
|
|||||||
GLOBAL int
|
GLOBAL int
|
||||||
main( int argc, const char *argv[] )
|
main( int argc, const char *argv[] )
|
||||||
{
|
{
|
||||||
|
struct passwd *pwd;
|
||||||
|
struct group *grp;
|
||||||
BOOLEAN ok, configtest = FALSE;
|
BOOLEAN ok, configtest = FALSE;
|
||||||
LONG pid, n;
|
LONG pid, n;
|
||||||
INT i;
|
INT i;
|
||||||
@ -275,8 +279,12 @@ main( int argc, const char *argv[] )
|
|||||||
if( setuid( Conf_UID ) != 0 ) Log( LOG_ERR, "Can't change User-ID to %u: %s", Conf_UID, strerror( errno ));
|
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, with PID %ld.", (LONG)getuid( ), (LONG)getgid( ), (LONG)getpid( ));
|
|
||||||
|
/* User, Gruppe und Prozess-ID des Daemon ausgeben */
|
||||||
|
pwd = getpwuid( getuid( )); grp = getgrgid( getgid( ));
|
||||||
|
Log( LOG_INFO, "Running as user %s(%ld), group %s(%ld), with PID %ld.", pwd ? pwd->pw_name : "unknown", (LONG)getuid( ), grp ? grp->gr_name : "unknown", (LONG)getgid( ), (LONG)getpid( ));
|
||||||
|
|
||||||
|
/* stderr in "Error-File" umlenken */
|
||||||
Log_InitErrorfile( );
|
Log_InitErrorfile( );
|
||||||
|
|
||||||
/* Signal-Handler initialisieren */
|
/* Signal-Handler initialisieren */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user