+/**
+ * @file
+ * Configuration management (header)
+ */
+
+#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"
+
+/**
+ * Configured IRC operator.
+ * Please note the the name of the IRC operaor and his nick have nothing to
+ * do with each other! The IRC operator is only identified by the name and
+ * password configured in this structure.
+ */
+struct Conf_Oper {
+ char name[CLIENT_PASS_LEN]; /**< Name (ID) */
+ char pwd[CLIENT_PASS_LEN]; /**< Password */
+ char *mask; /**< Allowed host mask */
+};
+
+/**
+ * Configured server.
+ * Peers to which this daemon should establish an outgoing server link must
+ * have set a port number; all other servers are allowed to connect to this one.
+ */
+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 the peer */
+ UINT16 port; /**< Server port to connect to */
+ int group; /**< Group ID of this server */
+ time_t lasttry; /**< Time of last connection attempt */
+ PROC_STAT res_stat; /**< Status of the resolver */
+ int flags; /**< Server 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; /**< Establish connection using SSL? */
+#endif
+ char svs_mask[CLIENT_ID_LEN]; /**< Mask of nick names that should be
+ treated and counted as services */
+} CONF_SERVER;
+
+
+#ifdef SSL_SUPPORT
+/** Configuration options required for SSL support */
+struct SSLOptions {
+ char *KeyFile; /**< SSL key file */
+ char *CertFile; /**< SSL certificate file */
+ char *DHFile; /**< File containing DH parameters */
+ array ListenPorts; /**< Array of listening SSL ports */
+ array KeyFilePassword; /**< Key file password */
+};
+#endif
+
+
+/** Pre-defined channels */
+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; /**< User limit 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 (ID, "nick") of this server */
+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 (MOTD) of this server */
+GLOBAL array Conf_Motd;
+
+/** Array of ports this server should listen on */
+GLOBAL array Conf_ListenPorts;
+
+/** Address to which sockets should be bound to or empty (=all) */
+GLOBAL char *Conf_ListenAddress;
+
+/** User and group ID this daemon should run with */
+GLOBAL uid_t Conf_UID;
+GLOBAL gid_t Conf_GID;
+
+/** The directory to chroot() into */
+GLOBAL char Conf_Chroot[FNAME_LEN];
+
+/** Full path and name of a file to which the PID of daemon should be written */
+GLOBAL char Conf_PidFile[FNAME_LEN];
+
+/** Timeout (in seconds) for PING commands */
+GLOBAL int Conf_PingTimeout;
+
+/** Timeout (in seconds) for PONG replies */
+GLOBAL int Conf_PongTimeout;