X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Fconf.h;h=ff67dc79349ac2bb31fc0f54d082904bcac99877;hp=93c8ebf0d241b320902281c355188f0ea0489cba;hb=5e82a91d1337b78510bc62fe3c7e43f9c0b7d3d1;hpb=112102b10ce991340ba56e272e32bc50a73e1b05 diff --git a/src/ngircd/conf.h b/src/ngircd/conf.h index 93c8ebf0..ff67dc79 100644 --- a/src/ngircd/conf.h +++ b/src/ngircd/conf.h @@ -1,6 +1,6 @@ /* * ngIRCd -- The Next Generation IRC Daemon - * Copyright (c)2001,2002 by Alexander Barton (alex@barton.de) + * Copyright (c)2001-2010 Alexander Barton (alex@barton.de) * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -8,8 +8,6 @@ * (at your option) any later version. * Please read the file COPYING, README and AUTHORS for more information. * - * $Id: conf.h,v 1.30 2005/02/04 14:24:21 alex Exp $ - * * Configuration management (header) */ @@ -20,35 +18,62 @@ #include #include "defines.h" +#include "array.h" +#include "portab.h" +#include "tool.h" +#include "ng_ipaddr.h" +#include "proc.h" +#include "conf-ssl.h" -typedef struct _Conf_Oper -{ - CHAR name[CLIENT_PASS_LEN]; /* Name (ID) of IRC operator */ - CHAR pwd[CLIENT_PASS_LEN]; /* Password */ -} CONF_OPER; +struct Conf_Oper { + char name[CLIENT_PASS_LEN]; /* Name (ID) of IRC operator */ + char pwd[CLIENT_PASS_LEN]; /* Password */ + char *mask; /* allowed host mask */ +}; typedef struct _Conf_Server { - CHAR host[HOST_LEN]; /* Hostname */ - CHAR ip[16]; /* IP address (Resolver) */ - CHAR name[CLIENT_ID_LEN]; /* IRC-Client-ID */ - CHAR pwd_in[CLIENT_PASS_LEN]; /* Password which must be received */ - CHAR pwd_out[CLIENT_PASS_LEN]; /* Password to send to peer */ - INT port; /* Server port */ - INT group; /* Group of server */ + char host[HOST_LEN]; /* Hostname */ + char name[CLIENT_ID_LEN]; /* IRC-Client-ID */ + char pwd_in[CLIENT_PASS_LEN]; /* Password which must be received */ + char pwd_out[CLIENT_PASS_LEN]; /* Password to send to peer */ + UINT16 port; /* Server port */ + int group; /* Group of server */ time_t lasttry; /* Last connect attempt */ - RES_STAT *res_stat; /* Status of the resolver */ - INT flags; /* Flags */ + PROC_STAT res_stat; /* Status of the resolver */ + int flags; /* Flags */ CONN_ID conn_id; /* ID of server connection or NONE */ + ng_ipaddr_t bind_addr; /* source address to use for outgoing + connections */ + ng_ipaddr_t dst_addr[2]; /* list of addresses to connect to */ +#ifdef SSL_SUPPORT + bool SSLConnect; /* connect() using SSL? */ +#endif + char svs_mask[CLIENT_ID_LEN]; /* Mask of nick names that are + services */ } CONF_SERVER; -typedef struct _Conf_Channel -{ - CHAR name[CHANNEL_NAME_LEN]; /* Name of the channel */ - CHAR modes[CHANNEL_MODE_LEN]; /* Initial channel modes */ - CHAR topic[CHANNEL_TOPIC_LEN]; /* Initial topic */ -} CONF_CHANNEL; + +#ifdef SSL_SUPPORT +struct SSLOptions { + char *KeyFile; + char *CertFile; + char *DHFile; + array ListenPorts; + array KeyFilePassword; +}; +#endif + + +struct Conf_Channel { + char name[CHANNEL_NAME_LEN]; /* Name of the channel */ + char modes[CHANNEL_MODE_LEN]; /* Initial channel modes */ + char key[CLIENT_PASS_LEN]; /* Channel key ("password", mode "k" ) */ + char topic[COMMAND_LEN]; /* Initial topic */ + char keyfile[512]; /* Path and name of channel key file */ + unsigned long maxusers; /* maximum usercount for this channel, mode "l" */ +}; #define CONF_SFLAG_ONCE 1 /* Delete this entry after next disconnect */ @@ -56,84 +81,126 @@ typedef struct _Conf_Channel /* Name ("Nick") of the servers */ -GLOBAL CHAR Conf_ServerName[CLIENT_ID_LEN]; +GLOBAL char Conf_ServerName[CLIENT_ID_LEN]; /* Server info text */ -GLOBAL CHAR Conf_ServerInfo[CLIENT_INFO_LEN]; +GLOBAL char Conf_ServerInfo[CLIENT_INFO_LEN]; /* Global server passwort */ -GLOBAL CHAR Conf_ServerPwd[CLIENT_PASS_LEN]; +GLOBAL char Conf_ServerPwd[CLIENT_PASS_LEN]; /* Administrative information */ -GLOBAL CHAR Conf_ServerAdmin1[CLIENT_INFO_LEN]; -GLOBAL CHAR Conf_ServerAdmin2[CLIENT_INFO_LEN]; -GLOBAL CHAR Conf_ServerAdminMail[CLIENT_INFO_LEN]; - -/* File with MOTD text */ -GLOBAL CHAR Conf_MotdFile[FNAME_LEN]; +GLOBAL char Conf_ServerAdmin1[CLIENT_INFO_LEN]; +GLOBAL char Conf_ServerAdmin2[CLIENT_INFO_LEN]; +GLOBAL char Conf_ServerAdminMail[CLIENT_INFO_LEN]; -/* Phrase with MOTD text */ -GLOBAL CHAR Conf_MotdPhrase[LINE_LEN]; +/* Message of the Day */ +GLOBAL array Conf_Motd; /* Ports the server should listen on */ -GLOBAL UINT Conf_ListenPorts[MAX_LISTEN_PORTS]; -GLOBAL INT Conf_ListenPorts_Count; +GLOBAL array Conf_ListenPorts; /* Address to which the socket should be bound or empty (=all) */ -GLOBAL CHAR Conf_ListenAddress[16]; +GLOBAL char *Conf_ListenAddress; /* User and group ID the server should run with */ -GLOBAL UINT Conf_UID; -GLOBAL UINT Conf_GID; +GLOBAL uid_t Conf_UID; +GLOBAL gid_t Conf_GID; /* A directory to chroot() in */ -GLOBAL CHAR Conf_Chroot[FNAME_LEN]; +GLOBAL char Conf_Chroot[FNAME_LEN]; /* File with PID of daemon */ -GLOBAL CHAR Conf_PidFile[FNAME_LEN]; +GLOBAL char Conf_PidFile[FNAME_LEN]; /* Timeouts for PING and PONG */ -GLOBAL INT Conf_PingTimeout; -GLOBAL INT Conf_PongTimeout; +GLOBAL int Conf_PingTimeout; +GLOBAL int Conf_PongTimeout; /* Seconds between connect attempts to other servers */ -GLOBAL INT Conf_ConnectRetry; +GLOBAL int Conf_ConnectRetry; /* Operators */ -GLOBAL CONF_OPER Conf_Oper[MAX_OPERATORS]; -GLOBAL INT Conf_Oper_Count; +GLOBAL array Conf_Opers; /* Servers */ GLOBAL CONF_SERVER Conf_Server[MAX_SERVERS]; /* Pre-defined channels */ -GLOBAL CONF_CHANNEL Conf_Channel[MAX_DEFCHANNELS]; -GLOBAL INT Conf_Channel_Count; +GLOBAL array Conf_Channels; + +/* Pre-defined channels only */ +GLOBAL bool Conf_PredefChannelsOnly; /* Are IRC operators allowed to always use MODE? */ -GLOBAL BOOLEAN Conf_OperCanMode; +GLOBAL bool Conf_OperCanMode; + +/* If an IRC op gives chanop privileges without being a chanop, + * ircd2 will ignore the command. This enables a workaround: + * It masks the command as coming from the server */ +GLOBAL bool Conf_OperServerMode; + +/* Are remote IRC operators allowed to manage this server? */ +GLOBAL bool Conf_AllowRemoteOper; + +/* Disable all DNS functions? */ +GLOBAL bool Conf_NoDNS; + +/* Disable IDENT lookups, even when compiled with support for it */ +GLOBAL bool Conf_NoIdent; + +/* Disable all usage of PAM, even when compiled with support for it */ +GLOBAL bool Conf_NoPAM; + +/* + * try to connect to remote systems using the ipv6 protocol, + * if they have an ipv6 address? (default yes) + */ +GLOBAL bool Conf_ConnectIPv6; + +/* same as above, but for ipv4 hosts, default: yes */ +GLOBAL bool Conf_ConnectIPv4; /* Maximum number of connections to this server */ -GLOBAL LONG Conf_MaxConnections; +GLOBAL long Conf_MaxConnections; /* Maximum number of channels a user can join */ -GLOBAL INT Conf_MaxJoins; +GLOBAL int Conf_MaxJoins; /* Maximum number of connections per IP address */ -GLOBAL INT Conf_MaxConnectionsIP; +GLOBAL int Conf_MaxConnectionsIP; + +/* Maximum length of a nick name */ +GLOBAL unsigned int Conf_MaxNickLength; +#ifdef SYSLOG -GLOBAL VOID Conf_Init PARAMS((VOID )); -GLOBAL VOID Conf_Rehash PARAMS((VOID )); -GLOBAL INT Conf_Test PARAMS((VOID )); +/* Syslog "facility" */ +GLOBAL int Conf_SyslogFacility; -GLOBAL VOID Conf_UnsetServer PARAMS(( CONN_ID Idx )); -GLOBAL VOID Conf_SetServer PARAMS(( INT ConfServer, CONN_ID Idx )); -GLOBAL INT Conf_GetServer PARAMS(( CONN_ID Idx )); +#endif -GLOBAL BOOLEAN Conf_EnableServer PARAMS(( CHAR *Name, INT Port )); -GLOBAL BOOLEAN Conf_DisableServer PARAMS(( CHAR *Name )); -GLOBAL BOOLEAN Conf_AddServer PARAMS(( CHAR *Name, INT Port, CHAR *Host, CHAR *MyPwd, CHAR *PeerPwd )); +GLOBAL void Conf_Init PARAMS((void)); +GLOBAL bool Conf_Rehash PARAMS((void)); +GLOBAL int Conf_Test PARAMS((void)); + +GLOBAL void Conf_UnsetServer PARAMS(( CONN_ID Idx )); +GLOBAL void Conf_SetServer PARAMS(( int ConfServer, CONN_ID Idx )); +GLOBAL int Conf_GetServer PARAMS(( CONN_ID Idx )); + +GLOBAL bool Conf_EnableServer PARAMS(( const char *Name, UINT16 Port )); +GLOBAL bool Conf_EnablePassiveServer PARAMS((const char *Name)); +GLOBAL bool Conf_DisableServer PARAMS(( const char *Name )); +GLOBAL bool Conf_AddServer PARAMS(( const char *Name, UINT16 Port, const char *Host, const char *MyPwd, const char *PeerPwd )); + +GLOBAL bool Conf_IsService PARAMS((int ConfServer, const char *Nick)); + +/* Password required by WEBIRC command */ +GLOBAL char Conf_WebircPwd[CLIENT_PASS_LEN]; + +#ifdef DEBUG +GLOBAL void Conf_DebugDump PARAMS((void)); +#endif #endif