/* * libretroshare/src/pqi: p3cfgmgr.h * * 3P/PQI network interface for RetroShare. * * Copyright 2007-2008 by Robert Fernie. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License Version 2 as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. * * Please report all bugs and problems to "retroshare@lunamutt.com". * */ #ifndef P3_CONFIG_MGR_HEADER #define P3_CONFIG_MGR_HEADER #include #include #include #include "pqi/pqi_base.h" #include "pqi/pqiindic.h" #include "pqi/pqinetwork.h" #include "util/rsthreads.h" #include "pqi/pqibin.h" /***** Configuration Management ***** * * we need to store: * (1) Certificates. * (2) List of Friends / Net Configuration * (3) Stun List. / DHT peers. * (4) general config. * * * At top level we need: * * - type / filename / size / hash - * and the file signed... * * */ /**** THESE are STORED in CONFIGURATION FILES.... * Cannot be changed * *********************/ /* CACHE ID Must be at the END so that other configurations * are loaded First (Cache Config --> Cache Loading) */ class p3ConfigMgr; //! abstract class for configuration saving /*! * Aim is that active objects in retroshare can dervie from this class * and implement their method of saving and loading their configuration */ class pqiConfig { public: pqiConfig(); virtual ~pqiConfig(); /** * loads configuration of object * @param loadHash This is the hash that will be compared to confirm saved configuration has not * been tampered with */ virtual bool loadConfiguration(RsFileHash &loadHash) = 0; /** * save configuration of object */ virtual bool saveConfiguration() = 0; /** * The name of the configuration file */ const std::string& Filename(); /** * The hash computed for this configuration, can use this to compare to externally stored hash * for validation checking */ const RsFileHash& Hash(); protected: /** * Checks if configuration has changed */ virtual void IndicateConfigChanged(); void setHash(const RsFileHash& h); RsMutex cfgMtx; private: /** * This sets the name of the pqi configuation file */ void setFilename(const std::string& name); /** * @param an index for the Confind which contains list of configuarations that can be tracked */ bool HasConfigChanged(uint16_t idx); Indicator ConfInd; std::string filename; RsFileHash hash; friend class p3ConfigMgr; /* so it can access: * setFilename() and HasConfigChanged() */ }; /***********************************************************************************************/ /*! * MUTEX NOTE * Class data is protected by mutex's so that anyone can call these * functions, at any time. */ class p3ConfigMgr { public: /** * @param bdir base directory: where config files will be saved */ p3ConfigMgr(std::string bdir); /** * checks and update all added configurations * @see rsserver */ void tick(); /** * save all added configuation including configuration files * creates global signature file */ void saveConfiguration(); /** * loads all configurations */ void loadConfiguration(); /** * @param file The name for new configuration * @param conf to the configuration to use */ void addConfiguration(std::string file, pqiConfig *conf); /** saves config, and disables further saving * used for exiting the system */ void completeConfiguration(); private: /** * saves configuration of pqiconfigs in object configs */ void saveConfig(); /** * */ void loadConfig(); const std::string basedir; RsMutex cfgMtx; /* below is protected */ bool mConfigSaveActive; std::list mConfigs; }; /***************************************************************************************************/ /** * @brief Abstract class for configuration saving. * Aimed at rs services that uses RsItem config data, provide a way for RS * services to save and load particular configurations as items. */ struct p3Config : pqiConfig { p3Config(); virtual bool loadConfiguration(RsFileHash &loadHash); virtual bool saveConfiguration(); protected: /// Key Functions to be overloaded for Full Configuration virtual RsSerialiser *setupSerialiser() = 0; /** * saves list of derived object * @param cleanup this inform you if you need to call saveDone() to * unlock/allow access to resources pointed to by handles (list) * returned by function: thus false, call saveDone after returned list * finished with and vice versa * @return list of config items derived object wants to saves */ virtual bool saveList(bool &cleanup, std::list&) = 0; /** * loads up list of configs items for derived object * @param load list of config items to load up */ virtual bool loadList(std::list& load) = 0; /** * callback for mutex unlocking * in derived classes (should only be needed if cleanup = false) */ virtual void saveDone() {} private: bool loadConfig(); bool saveConfig(); bool loadAttempt( const std::string&, const std::string&, std::list& load ); }; // end of p3Config class p3GeneralConfig: public p3Config { public: p3GeneralConfig(); // General Configuration System std::string getSetting(const std::string &opt); void setSetting(const std::string &opt, const std::string &val); protected: /* Key Functions to be overloaded for Full Configuration */ virtual RsSerialiser *setupSerialiser(); virtual bool saveList(bool &cleanup, std::list&); virtual bool loadList(std::list& ); private: /* protected by pqiConfig mutex as well! */ std::map settings; }; #endif // P3_CONFIG_MGR_HEADER