+#include <time.h>
+
+#include "defines.h"
+#include "array.h"
+#include "portab.h"
+#include "tool.h"
+#include "ng_ipaddr.h"
+#include "proc.h"
+#include "conf-ssl.h"
+
+
+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 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 */
+ 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;
+
+
+#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 */
+#define CONF_SFLAG_DISABLED 2 /* This server configuration entry is disabled */
+
+
+/* Name ("Nick") of the servers */
+GLOBAL char Conf_ServerName[CLIENT_ID_LEN];
+
+/* Server info text */
+GLOBAL char Conf_ServerInfo[CLIENT_INFO_LEN];
+
+/* Global server passwort */
+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];
+
+/* Message of the Day */
+GLOBAL array Conf_Motd;
+
+/* Ports the server should listen on */
+GLOBAL array Conf_ListenPorts;
+
+/* Address to which the socket should be bound or empty (=all) */
+GLOBAL char *Conf_ListenAddress;
+
+/* User and group ID the server should run with */
+GLOBAL uid_t Conf_UID;
+GLOBAL gid_t Conf_GID;
+
+/* A directory to chroot() in */
+GLOBAL char Conf_Chroot[FNAME_LEN];
+
+/* File with PID of daemon */
+GLOBAL char Conf_PidFile[FNAME_LEN];
+
+/* Timeouts for PING and PONG */
+GLOBAL int Conf_PingTimeout;
+GLOBAL int Conf_PongTimeout;
+
+/* Seconds between connect attempts to other servers */
+GLOBAL int Conf_ConnectRetry;
+
+/* Operators */
+GLOBAL array Conf_Opers;
+
+/* Servers */
+GLOBAL CONF_SERVER Conf_Server[MAX_SERVERS];
+
+/* Pre-defined channels */
+GLOBAL array Conf_Channels;
+
+/* Pre-defined channels only */
+GLOBAL bool Conf_PredefChannelsOnly;
+
+/* Are IRC operators allowed to always use MODE? */
+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;