conf.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. /*
  2. * ngIRCd -- The Next Generation IRC Daemon
  3. * Copyright (c)2001,2002 by Alexander Barton (alex@barton.de)
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. * Please read the file COPYING, README and AUTHORS for more information.
  10. *
  11. * $Id: conf.h,v 1.40.2.2 2007/04/03 22:08:52 fw Exp $
  12. *
  13. * Configuration management (header)
  14. */
  15. #ifndef __conf_h__
  16. #define __conf_h__
  17. #include <time.h>
  18. #include "defines.h"
  19. #include "array.h"
  20. #include "portab.h"
  21. typedef struct _Conf_Oper
  22. {
  23. char name[CLIENT_PASS_LEN]; /* Name (ID) of IRC operator */
  24. char pwd[CLIENT_PASS_LEN]; /* Password */
  25. char *mask;
  26. } CONF_OPER;
  27. typedef struct _Conf_Server
  28. {
  29. char host[HOST_LEN]; /* Hostname */
  30. char ip[16]; /* IP address (Resolver) */
  31. char name[CLIENT_ID_LEN]; /* IRC-Client-ID */
  32. char pwd_in[CLIENT_PASS_LEN]; /* Password which must be received */
  33. char pwd_out[CLIENT_PASS_LEN]; /* Password to send to peer */
  34. UINT16 port; /* Server port */
  35. int group; /* Group of server */
  36. time_t lasttry; /* Last connect attempt */
  37. RES_STAT res_stat; /* Status of the resolver */
  38. int flags; /* Flags */
  39. CONN_ID conn_id; /* ID of server connection or NONE */
  40. } CONF_SERVER;
  41. typedef struct _Conf_Channel
  42. {
  43. char name[CHANNEL_NAME_LEN]; /* Name of the channel */
  44. char modes[CHANNEL_MODE_LEN]; /* Initial channel modes */
  45. char key[CLIENT_PASS_LEN]; /* Channel key ("password", mode "k" ) */
  46. unsigned long maxusers; /* maximum usercount for this channel, mode "l" */
  47. array topic; /* Initial topic */
  48. } CONF_CHANNEL;
  49. #define CONF_SFLAG_ONCE 1 /* Delete this entry after next disconnect */
  50. #define CONF_SFLAG_DISABLED 2 /* This server configuration entry is disabled */
  51. /* Name ("Nick") of the servers */
  52. GLOBAL char Conf_ServerName[CLIENT_ID_LEN];
  53. /* Server info text */
  54. GLOBAL char Conf_ServerInfo[CLIENT_INFO_LEN];
  55. /* Global server passwort */
  56. GLOBAL char Conf_ServerPwd[CLIENT_PASS_LEN];
  57. /* Administrative information */
  58. GLOBAL char Conf_ServerAdmin1[CLIENT_INFO_LEN];
  59. GLOBAL char Conf_ServerAdmin2[CLIENT_INFO_LEN];
  60. GLOBAL char Conf_ServerAdminMail[CLIENT_INFO_LEN];
  61. /* File with MOTD text */
  62. GLOBAL char Conf_MotdFile[FNAME_LEN];
  63. /* Phrase with MOTD text */
  64. GLOBAL char Conf_MotdPhrase[LINE_LEN];
  65. /* Ports the server should listen on */
  66. GLOBAL array Conf_ListenPorts;
  67. /* Address to which the socket should be bound or empty (=all) */
  68. GLOBAL char Conf_ListenAddress[16];
  69. /* User and group ID the server should run with */
  70. GLOBAL uid_t Conf_UID;
  71. GLOBAL gid_t Conf_GID;
  72. /* A directory to chroot() in */
  73. GLOBAL char Conf_Chroot[FNAME_LEN];
  74. /* File with PID of daemon */
  75. GLOBAL char Conf_PidFile[FNAME_LEN];
  76. /* Timeouts for PING and PONG */
  77. GLOBAL int Conf_PingTimeout;
  78. GLOBAL int Conf_PongTimeout;
  79. /* Seconds between connect attempts to other servers */
  80. GLOBAL int Conf_ConnectRetry;
  81. /* Operators */
  82. GLOBAL CONF_OPER Conf_Oper[MAX_OPERATORS];
  83. GLOBAL unsigned int Conf_Oper_Count;
  84. /* Servers */
  85. GLOBAL CONF_SERVER Conf_Server[MAX_SERVERS];
  86. /* Pre-defined channels */
  87. GLOBAL CONF_CHANNEL Conf_Channel[MAX_DEFCHANNELS];
  88. GLOBAL unsigned int Conf_Channel_Count;
  89. /* Pre-defined channels only */
  90. GLOBAL bool Conf_PredefChannelsOnly;
  91. /* Are IRC operators allowed to always use MODE? */
  92. GLOBAL bool Conf_OperCanMode;
  93. /* If an IRC op gives chanop privileges without being a chanop,
  94. * ircd2 will ignore the command. This enables a workaround:
  95. * It masks the command as coming from the server */
  96. GLOBAL bool Conf_OperServerMode;
  97. /* Maximum number of connections to this server */
  98. GLOBAL long Conf_MaxConnections;
  99. /* Maximum number of channels a user can join */
  100. GLOBAL int Conf_MaxJoins;
  101. /* Maximum number of connections per IP address */
  102. GLOBAL int Conf_MaxConnectionsIP;
  103. GLOBAL void Conf_Init PARAMS((void));
  104. GLOBAL void Conf_Rehash PARAMS((void));
  105. GLOBAL int Conf_Test PARAMS((void));
  106. GLOBAL void Conf_UnsetServer PARAMS(( CONN_ID Idx ));
  107. GLOBAL void Conf_SetServer PARAMS(( int ConfServer, CONN_ID Idx ));
  108. GLOBAL int Conf_GetServer PARAMS(( CONN_ID Idx ));
  109. GLOBAL bool Conf_EnableServer PARAMS(( char *Name, UINT16 Port ));
  110. GLOBAL bool Conf_DisableServer PARAMS(( char *Name ));
  111. GLOBAL bool Conf_AddServer PARAMS(( char *Name, UINT16 Port, char *Host, char *MyPwd, char *PeerPwd ));
  112. #endif
  113. /* -eof- */