X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/641204dfbdb9fc870cdd2e7f9e3169a44693e7bf..5dfab5bea026e33031d041b233c73e196469b4ac:/projects/stargazer/plugins/capture/ether_linux/ether_cap.h diff --git a/projects/stargazer/plugins/capture/ether_linux/ether_cap.h b/projects/stargazer/plugins/capture/ether_linux/ether_cap.h index 9643076b..d50923d6 100644 --- a/projects/stargazer/plugins/capture/ether_linux/ether_cap.h +++ b/projects/stargazer/plugins/capture/ether_linux/ether_cap.h @@ -23,72 +23,63 @@ * Author : Boris Mikhailenko */ -#ifndef ETHER_CAP_H -#define ETHER_CAP_H +#pragma once + +#include "stg/plugin.h" +#include "stg/module_settings.h" +#include "stg/logger.h" #include -#include +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wshadow" +#include +#pragma GCC diagnostic pop -#include "base_plugin.h" -#include "base_settings.h" -#include "../../../traffcounter.h" +namespace STG +{ -using namespace std; +struct Users; +struct Tariffs; +struct Admins; +struct TraffCounter; +struct Settings; -extern "C" BASE_PLUGIN * GetPlugin(); +} //----------------------------------------------------------------------------- -class ETHER_CAP_SETTINGS -{ -public: - const string& GetStrError() const { static string s; return s; } - int ParseSettings(const MODULE_SETTINGS &) { return 0; } -}; -//----------------------------------------------------------------------------- -class ETHER_CAP :public BASE_PLUGIN -{ +class ETHER_CAP : public STG::Plugin { public: ETHER_CAP(); - virtual ~ETHER_CAP(){}; - void SetUsers(USERS *){}; - void SetTariffs(TARIFFS *){}; - void SetAdmins(ADMINS *){}; - void SetTraffcounter(TRAFFCOUNTER * tc); - void SetStore(BASE_STORE *){}; - void SetStgSettings(const SETTINGS *){}; + void SetTraffcounter(STG::TraffCounter * tc) { traffCnt = tc; } int Start(); int Stop(); - int Reload() { return 0; }; - bool IsRunning(); + int Reload(const STG::ModuleSettings & /*ms*/) { return 0; } + bool IsRunning() { return isRunning; } - void SetSettings(const MODULE_SETTINGS &){}; - int ParseSettings(){ return 0; }; - const string & GetStrError() const; - const string GetVersion() const; - uint16_t GetStartPosition() const; - uint16_t GetStopPosition() const; + int ParseSettings() { return 0; } + const std::string & GetStrError() const { return errorStr; } + std::string GetVersion() const; + uint16_t GetStartPosition() const { return 40; } + uint16_t GetStopPosition() const { return 40; } private: - static void * Run(void *); + ETHER_CAP(const ETHER_CAP & rvalue); + ETHER_CAP & operator=(const ETHER_CAP & rvalue); + + void Run(std::stop_token token); int EthCapOpen(); int EthCapClose(); int EthCapRead(void * buffer, int blen, char ** iface); - bool WaitPackets(int sd) const; - - ETHER_CAP_SETTINGS capSettings; - mutable string errorStr; + mutable std::string errorStr; - pthread_t thread; - bool nonstop; + std::jthread m_thread; bool isRunning; int capSock; - TRAFFCOUNTER * traffCnt; -}; -//----------------------------------------------------------------------------- - -#endif //ETHER_CAP_H + STG::TraffCounter * traffCnt; + STG::PluginLogger logger; +};