X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/8c6fa3fbaccc22127280bf77a48fab5a3ee0716e..46b0747592074017ff0ea4b33d4a7194235886e5:/stargazer/plugins/store/postgresql/postgresql_store.h diff --git a/stargazer/plugins/store/postgresql/postgresql_store.h b/stargazer/plugins/store/postgresql/postgresql_store.h new file mode 100644 index 00000000..6bcb3cd0 --- /dev/null +++ b/stargazer/plugins/store/postgresql/postgresql_store.h @@ -0,0 +1,160 @@ +/* + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +/* + * Author : Maxim Mamontov + */ + +/* + * PostgreSQL storage class definition + * + * $Revision: 1.8 $ + * $Date: 2010/01/19 11:06:53 $ + * + */ + +#ifndef POSTGRESQL_STORE_H +#define POSTGRESQL_STORE_H + +#include + +#include +#include + +#include "stg/store.h" +#include "stg/logger.h" + +// Minimal DB version is 5 +// Recommended DB version is 6 (support FreeMb logging on disconnects) +#define DB_MIN_VERSION 5 + +class POSTGRESQL_STORE : public STORE { +public: + POSTGRESQL_STORE(); + virtual ~POSTGRESQL_STORE(); + + // Users + int GetUsersList(std::vector * usersList) const; + int AddUser(const std::string & login) const; + int DelUser(const std::string & login) const; + int SaveUserStat(const USER_STAT & stat, const std::string & login) const; + int SaveUserConf(const USER_CONF & conf, const std::string & login) const; + int RestoreUserStat(USER_STAT * stat, const std::string & login) const; + int RestoreUserConf(USER_CONF * conf, const std::string & login) const; + int WriteUserChgLog(const std::string & login, + const std::string & admLogin, + uint32_t admIP, + const std::string & paramName, + const std::string & oldValue, + const std::string & newValue, + const std::string & message) const; + int WriteUserConnect(const std::string & login, uint32_t ip) const; + int WriteUserDisconnect(const std::string & login, + const DIR_TRAFF & up, + const DIR_TRAFF & down, + const DIR_TRAFF & sessionUp, + const DIR_TRAFF & sessionDown, + double cash, + double freeMb, + const std::string & reason) const; + int WriteDetailedStat(const TRAFF_STAT & statTree, + time_t lastStat, + const std::string & login) const; + + // Messages + int AddMessage(STG_MSG * msg, const std::string & login) const; + int EditMessage(const STG_MSG & msg, const std::string & login) const; + int GetMessage(uint64_t id, STG_MSG * msg, const std::string & login) const; + int DelMessage(uint64_t id, const std::string & login) const; + int GetMessageHdrs(std::vector * hdrsList, const std::string & login) const; + + // Stats + int SaveMonthStat(const USER_STAT & stat, int month, int year, const std::string & login) const; + + // Admins + int GetAdminsList(std::vector * adminsList) const; + int SaveAdmin(const ADMIN_CONF & ac) const; + int RestoreAdmin(ADMIN_CONF * ac, const std::string & login) const; + int AddAdmin(const std::string & login) const; + int DelAdmin(const std::string & login) const; + + // Tariffs + int GetTariffsList(std::vector * tariffsList) const; + int AddTariff(const std::string & name) const; + int DelTariff(const std::string & name) const; + int SaveTariff(const TARIFF_DATA & td, const std::string & tariffName) const; + int RestoreTariff(TARIFF_DATA * td, const std::string & tariffName) const; + + // Corporations + int GetCorpsList(std::vector * corpsList) const; + int SaveCorp(const CORP_CONF & cc) const; + int RestoreCorp(CORP_CONF * cc, const std::string & name) const; + int AddCorp(const std::string & name) const; + int DelCorp(const std::string & name) const; + + // Services + int GetServicesList(std::vector * servicesList) const; + int SaveService(const SERVICE_CONF & sc) const; + int RestoreService(SERVICE_CONF * sc, const std::string & name) const; + int AddService(const std::string & name) const; + int DelService(const std::string & name) const; + + // Settings + inline void SetSettings(const MODULE_SETTINGS & s) { settings = s; } + int ParseSettings(); + + inline const std::string & GetStrError() const { return strError; } + inline const std::string & GetVersion() const { return versionString; } +private: + POSTGRESQL_STORE(const POSTGRESQL_STORE & rvalue); + POSTGRESQL_STORE & operator=(const POSTGRESQL_STORE & rvalue); + + int StartTransaction() const; + int CommitTransaction() const; + int RollbackTransaction() const; + + int EscapeString(std::string & value) const; + + int SaveStat(const USER_STAT & stat, const std::string & login, int year = 0, int month = 0) const; + + int SaveUserServices(uint32_t uid, const std::vector & services) const; + int SaveUserData(uint32_t uid, const std::vector & data) const; + int SaveUserIPs(uint32_t uid, const USER_IPS & ips) const; + + void MakeDate(std::string & date, int year = 0, int month = 0) const; + + int Connect(); + int Reset() const; + int CheckVersion() const; + + std::string versionString; + mutable std::string strError; + std::string server; + std::string database; + std::string user; + std::string password; + std::string clientEncoding; + MODULE_SETTINGS settings; + mutable pthread_mutex_t mutex; + mutable int version; + int retries; + + PGconn * connection; + + PLUGIN_LOGGER logger; +}; + +#endif //POSTGRESQL_STORE_H