/* * * (C) 2003-2022 Anope Team * Contact us at team@anope.org * * Please read COPYING and README for further details. * * Based on the original code of Epona by Lara. * Based on the original code of Services by Andy Church. */ #ifndef CONFIG_H #define CONFIG_H #include "account.h" #include "regchannel.h" #include "users.h" #include "opertype.h" #include namespace Configuration { class CoreExport Block { friend struct Conf; public: typedef Anope::map item_map; typedef Anope::multimap block_map; private: Anope::string name; item_map items; block_map blocks; int linenum; public: Block(const Anope::string &); const Anope::string &GetName() const; int CountBlock(const Anope::string &name); Block* GetBlock(const Anope::string &name, int num = 0); template inline T Get(const Anope::string &tag) { return this->Get(tag, ""); } /* VS 2008 has an issue with having a default argument here (def = ""), which is why the above * function exists. */ template T Get(const Anope::string &tag, const Anope::string &def) const { const Anope::string &value = this->Get(tag, def); if (!value.empty()) try { return convertTo(value); } catch (const ConvertException &) { } return T(); } bool Set(const Anope::string &tag, const Anope::string &value); const item_map* GetItems() const; }; template<> CoreExport const Anope::string Block::Get(const Anope::string &tag, const Anope::string& def) const; template<> CoreExport time_t Block::Get(const Anope::string &tag, const Anope::string &def) const; template<> CoreExport bool Block::Get(const Anope::string &tag, const Anope::string &def) const; /** Represents a configuration file */ class File { Anope::string name; bool executable; FILE *fp; public: File(const Anope::string &, bool); ~File(); const Anope::string &GetName() const; Anope::string GetPath() const; bool IsOpen() const; bool Open(); void Close(); bool End() const; Anope::string Read(); }; struct Uplink; struct CoreExport Conf : Block { /* options:readtimeout */ time_t ReadTimeout; /* options:useprivmsg */ bool UsePrivmsg; /* If we should default to privmsging clients */ bool DefPrivmsg; /* Default language */ Anope::string DefLanguage; /* options:timeoutcheck */ time_t TimeoutCheck; /* options:usestrictprivmsg */ bool UseStrictPrivmsg; /* networkinfo:nickchars */ Anope::string NickChars; /* either "/msg " or "/" */ Anope::string StrictPrivmsg; /* List of uplink servers to try and connect to */ std::vector Uplinks; /* A vector of our logfile options */ std::vector LogInfos; /* Array of ulined servers */ std::vector Ulines; /* List of available opertypes */ std::vector MyOperTypes; /* List of pairs of opers and their opertype from the config */ std::vector Opers; /* Map of fantasy commands */ CommandInfo::map Fantasy; /* Command groups */ std::vector CommandGroups; /* List of modules to autoload */ std::vector ModulesAutoLoad; /* module configuration blocks */ std::map modules; Anope::map bots; Conf(); ~Conf(); void LoadConf(File &file); void Post(Conf *old); Block *GetModule(Module *); Block *GetModule(const Anope::string &name); BotInfo *GetClient(const Anope::string &name); Block *GetCommand(CommandSource &); }; struct Uplink { Anope::string host; unsigned port; Anope::string password; bool ipv6; Uplink(const Anope::string &_host, int _port, const Anope::string &_password, bool _ipv6) : host(_host), port(_port), password(_password), ipv6(_ipv6) { } inline bool operator==(const Uplink &other) const { return host == other.host && port == other.port && password == other.password && ipv6 == other.ipv6; } inline bool operator!=(const Uplink &other) const { return !(*this == other); } }; } /** This class can be used on its own to represent an exception, or derived to represent a module-specific exception. * When a module whishes to abort, e.g. within a constructor, it should throw an exception using ModuleException or * a class derived from ModuleException. If a module throws an exception during its constructor, the module will not * be loaded. If this happens, the error message returned by ModuleException::GetReason will be displayed to the user * attempting to load the module, or dumped to the console if the ircd is currently loading for the first time. */ class ConfigException : public CoreException { public: /** Default constructor, just uses the error message 'Config threw an exception'. */ ConfigException() : CoreException("Config threw an exception", "Config Parser") { } /** This constructor can be used to specify an error message before throwing. */ ConfigException(const Anope::string &message) : CoreException(message, "Config Parser") { } /** This destructor solves world hunger, cancels the world debt, and causes the world to end. * Actually no, it does nothing. Never mind. * @throws Nothing! */ virtual ~ConfigException() throw() { } }; extern Configuration::File ServicesConf; extern CoreExport Configuration::Conf *Config; #endif // CONFIG_H