X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/bc10181876b089f6293c259861075b392ea6ddfa..43ac308ea20014761481bc40525496a0bb1d9740:/projects/stargazer/plugins/configuration/sgconfig/stgconfig.h diff --git a/projects/stargazer/plugins/configuration/sgconfig/stgconfig.h b/projects/stargazer/plugins/configuration/sgconfig/stgconfig.h index 7a089eb0..f4f94ee8 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/stgconfig.h +++ b/projects/stargazer/plugins/configuration/sgconfig/stgconfig.h @@ -1,5 +1,24 @@ -#ifndef STGCONFIG_H -#define STGCONFIG_H +/* + * 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 : Boris Mikhailenko + */ + +#pragma once #include "configproto.h" @@ -7,59 +26,62 @@ #include "stg/logger.h" #include +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wshadow" +#include +#pragma GCC diagnostic pop -#include - -class STG_CONFIG_SETTINGS { -public: - STG_CONFIG_SETTINGS() : errorStr(), port(0) {} - virtual ~STG_CONFIG_SETTINGS() {} - const std::string & GetStrError() const { return errorStr; } - int ParseSettings(const MODULE_SETTINGS & s); - uint16_t GetPort() const { return port; } -private: - std::string errorStr; - uint16_t port; +class STG_CONFIG_SETTINGS +{ + public: + STG_CONFIG_SETTINGS() : m_port(0), m_bindAddress("0.0.0.0") {} + const std::string & GetStrError() const { return errorStr; } + bool ParseSettings(const STG::ModuleSettings & s); + uint16_t GetPort() const { return m_port; } + const std::string & GetBindAddress() const { return m_bindAddress; } + private: + std::string errorStr; + uint16_t m_port; + std::string m_bindAddress; }; -//----------------------------------------------------------------------------- -class STG_CONFIG :public PLUGIN { -public: - STG_CONFIG(); - virtual ~STG_CONFIG(){} - void SetUsers(USERS * users) { config.SetUsers(users); } - void SetTariffs(TARIFFS * tariffs) { config.SetTariffs(tariffs); } - void SetAdmins(ADMINS * admins) { config.SetAdmins(admins); } - void SetStore(STORE * store) { config.SetStore(store); } - void SetStgSettings(const SETTINGS * settings) { config.SetStgSettings(settings); } - void SetSettings(const MODULE_SETTINGS & s) { settings = s; } - int ParseSettings(); +class STG_CONFIG : public STG::Plugin +{ + public: + STG_CONFIG(); - int Start(); - int Stop(); - int Reload() { return 0; } - bool IsRunning() { return isRunning; } + void SetUsers(STG::Users * users) override { config.SetUsers(users); } + void SetTariffs(STG::Tariffs * tariffs) override { config.SetTariffs(tariffs); } + void SetAdmins(STG::Admins * admins) override { config.SetAdmins(admins); } + void SetServices(STG::Services * services) override { config.SetServices(services); } + void SetCorporations(STG::Corporations * corporations) override { config.SetCorporations( corporations); } + void SetStore(STG::Store * store) override { config.SetStore(store); } + void SetStgSettings(const STG::Settings * s) override { config.SetSettings(s); } + void SetSettings(const STG::ModuleSettings & s) override { settings = s; } + int ParseSettings() override; - const std::string & GetStrError() const { return errorStr; } - std::string GetVersion() const; - uint16_t GetStartPosition() const { return 20; } - uint16_t GetStopPosition() const { return 20; } + int Start() override; + int Stop() override; + int Reload(const STG::ModuleSettings & /*ms*/) override { return 0; } + bool IsRunning() override { return isRunning; } -private: - STG_CONFIG(const STG_CONFIG & rvalue); - STG_CONFIG & operator=(const STG_CONFIG & rvalue); + const std::string & GetStrError() const override { return errorStr; } + std::string GetVersion() const override { return "Stg Configurator v. 2.0"; } + uint16_t GetStartPosition() const override { return 20; } + uint16_t GetStopPosition() const override { return 20; } - static void * Run(void *); + private: + STG_CONFIG(const STG_CONFIG & rvalue); + STG_CONFIG & operator=(const STG_CONFIG & rvalue); - mutable std::string errorStr; - STG_CONFIG_SETTINGS stgConfigSettings; - pthread_t thread; - bool nonstop; - bool isRunning; - PLUGIN_LOGGER logger; - CONFIGPROTO config; - MODULE_SETTINGS settings; -}; -//----------------------------------------------------------------------------- + void Run(std::stop_token token); -#endif + mutable std::string errorStr; + STG_CONFIG_SETTINGS stgConfigSettings; + std::jthread m_thread; + bool nonstop; + bool isRunning; + STG::PluginLogger logger; + CONFIGPROTO config; + STG::ModuleSettings settings; +};