commit - 8da254ea74a1b099e6bcbda5c9a261db71203c51
commit + ae39724a63171b011e58b27f2754256ecba70a12
blob - db886ad6d8ae2c5e2e8223aada1a522d94c9263c
blob + 4220c5522a6ddf7f28019bf74553c4c62220328c
--- doc/sample-ngircd.conf
+++ doc/sample-ngircd.conf
-# $Id: sample-ngircd.conf,v 1.12 2002/11/02 23:13:18 alex Exp $
+# $Id: sample-ngircd.conf,v 1.13 2002/11/08 23:09:26 alex Exp $
#
# Das ist eine Beispiel-Konfiguration fuer den ngIRCd, die an die
;MotdFile = /usr/local/etc/ngircd.motd
# User-ID, unter der der Daemon laufen soll (dazu muss der Server
- # jedoch mit root-Rechten gestartet werden).
+ # jedoch mit root-Rechten gestartet werden). Es kann der Name oder
+ # die numerische ID angegeben werden.
# ACHTUNG: Die Konfigurations- und MOTD-Datei muessen fuer diesen
# Benutzer lesbar sein, ansonsten schlaegt ein RESTART fehl!
- ;ServerUID = 65534
+ ;ServerUID = ircd
# Group-ID, zu der der Daemon wechseln soll (hierzu muss der Server
- # jedoch mit root-Rechten gestartet werden)
- ;ServerGID = 65534
+ # jedoch mit root-Rechten gestartet werden). Es kann der Name oder
+ # die numerische ID angegeben werden.
+ ;ServerGID = daemon
# Nach <PingTimeout> Sekunden verschickt der Server bei Inaktivitaet
# von einem Client diesem ein PING.
blob - cf8b2684fb5b518ef310906b1ad6ec976f6e0349
blob + d87db500355933ccb7e3b8749a0be442c4b80cc1
--- src/ngircd/conf.c
+++ src/ngircd/conf.c
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
*
- * $Id: conf.c,v 1.35 2002/11/02 22:59:01 alex Exp $
+ * $Id: conf.c,v 1.36 2002/11/08 23:09:26 alex Exp $
*
* conf.h: Konfiguration des ngircd
*/
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
+#include <pwd.h>
+#include <grp.h>
+#include <sys/types.h>
#include "ngircd.h"
#include "conn.h"
{
/* Konfiguration einlesen, ueberpruefen und ausgeben. */
+ struct passwd *pwd;
+ struct group *grp;
INT i;
Use_Log = FALSE;
printf( "%u", Conf_ListenPorts[i] );
}
puts( "" );
- printf( " ServerUID = %ld\n", (LONG)Conf_UID );
- printf( " ServerGID = %ld\n", (LONG)Conf_GID );
+ pwd = getpwuid( Conf_UID );
+ 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( " PongTimeout = %d\n", Conf_PongTimeout );
printf( " ConnectRetry = %d\n", Conf_ConnectRetry );
LOCAL VOID
Handle_GLOBAL( INT Line, CHAR *Var, CHAR *Arg )
{
+ struct passwd *pwd;
+ struct group *grp;
CHAR *ptr;
LONG port;
if( strcasecmp( Var, "ServerUID" ) == 0 )
{
/* 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;
}
if( strcasecmp( Var, "ServerGID" ) == 0 )
{
/* 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;
}
if( strcasecmp( Var, "PingTimeout" ) == 0 )