X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/8569ecdc2c9368dc0fe650b901cce7b37337ffec..80aca6d78d4ff5d514216fe96c44e2ee75c4e933:/projects/stargazer/plugins/capture/ether_linux/ether_cap.h?ds=inline diff --git a/projects/stargazer/plugins/capture/ether_linux/ether_cap.h b/projects/stargazer/plugins/capture/ether_linux/ether_cap.h index 8dfb6c04..d50923d6 100644 --- a/projects/stargazer/plugins/capture/ether_linux/ether_cap.h +++ b/projects/stargazer/plugins/capture/ether_linux/ether_cap.h @@ -23,36 +23,39 @@ * Author : Boris Mikhailenko <stg34@stargazer.dp.ua> */ -#ifndef ETHER_CAP_H -#define ETHER_CAP_H - -#include <pthread.h> - -#include <string> +#pragma once #include "stg/plugin.h" #include "stg/module_settings.h" #include "stg/logger.h" -class USERS; -class TARIFFS; -class ADMINS; -class TRAFFCOUNTER; -class SETTINGS; +#include <string> +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wshadow" +#include <jthread.hpp> +#pragma GCC diagnostic pop + +namespace STG +{ + +struct Users; +struct Tariffs; +struct Admins; +struct TraffCounter; +struct Settings; -class TRAFFCOUNTER; +} //----------------------------------------------------------------------------- -class ETHER_CAP : public PLUGIN { +class ETHER_CAP : public STG::Plugin { public: ETHER_CAP(); - virtual ~ETHER_CAP() {} - void SetTraffcounter(TRAFFCOUNTER * tc) { traffCnt = tc; } + void SetTraffcounter(STG::TraffCounter * tc) { traffCnt = tc; } int Start(); int Stop(); - int Reload() { return 0; } + int Reload(const STG::ModuleSettings & /*ms*/) { return 0; } bool IsRunning() { return isRunning; } int ParseSettings() { return 0; } @@ -65,22 +68,18 @@ private: ETHER_CAP(const ETHER_CAP & rvalue); ETHER_CAP & operator=(const ETHER_CAP & rvalue); - static void * Run(void *); + void Run(std::stop_token token); int EthCapOpen(); int EthCapClose(); int EthCapRead(void * buffer, int blen, char ** iface); mutable std::string errorStr; - pthread_t thread; - bool nonstop; + std::jthread m_thread; bool isRunning; int capSock; - TRAFFCOUNTER * traffCnt; + STG::TraffCounter * traffCnt; - PLUGIN_LOGGER logger; + STG::PluginLogger logger; }; -//----------------------------------------------------------------------------- - -#endif