X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/0907aa4037b12b6b88ee24495d4577a064d4f8db..bc6cac0e474dfe2feb4983aef98f99e23a98ffc4:/projects/stargazer/traffcounter_impl.h diff --git a/projects/stargazer/traffcounter_impl.h b/projects/stargazer/traffcounter_impl.h index 78027cb5..d23f6306 100644 --- a/projects/stargazer/traffcounter_impl.h +++ b/projects/stargazer/traffcounter_impl.h @@ -33,10 +33,13 @@ #include #include #include +#include +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wshadow" +#include +#pragma GCC diagnostic pop #include -#include - #define PROTOMAX (5) namespace STG @@ -94,7 +97,7 @@ public: traffCnt(rvalue.traffCnt), user(rvalue.user) {} - void Notify(const uint32_t & oldValue, const uint32_t & newValue); + void notify(const uint32_t & oldValue, const uint32_t & newValue) override; void SetUser(UserImpl * u) { user = u; } UserImpl * GetUser() const { return user; } @@ -117,7 +120,7 @@ public: traffCnt(rvalue.traffCnt), user(rvalue.user) {} - void Notify(const uint32_t & oldValue, const uint32_t & newValue); + void notify(const uint32_t & oldValue, const uint32_t & newValue) override; void SetUser(UserImpl * u) { user = u; } UserImpl * GetUser() const { return user; } private: @@ -136,7 +139,7 @@ public: traffCnt(t) {} virtual ~ADD_USER_NONIFIER() {} - void Notify(const UserImplPtr & user); + void notify(const UserImplPtr & user) override; private: ADD_USER_NONIFIER(const ADD_USER_NONIFIER & rvalue); @@ -152,7 +155,7 @@ public: traffCnt(t) {} virtual ~DEL_USER_NONIFIER() {} - void Notify(const UserImplPtr & user); + void notify(const UserImplPtr & user) override; private: DEL_USER_NONIFIER(const DEL_USER_NONIFIER & rvalue); @@ -185,7 +188,7 @@ class TraffCounterImpl : public TraffCounter { void FreeRules(); bool ReadRules(bool test = false); - static void * Run(void * data); + void Run(std::stop_token token); void DeterminateDir(const RawPacket & packet, int * dirU, // Direction for upload @@ -223,10 +226,9 @@ class TraffCounterImpl : public TraffCounter { UsersImpl * users; - bool running; bool stopped; - pthread_mutex_t mutex; - pthread_t thread; + std::mutex m_mutex; + std::jthread m_thread; std::list ipBeforeNotifiers; std::list ipAfterNotifiers; @@ -236,36 +238,36 @@ class TraffCounterImpl : public TraffCounter { }; //----------------------------------------------------------------------------- inline -void TRF_IP_BEFORE::Notify(const uint32_t & oldValue, const uint32_t &) +void TRF_IP_BEFORE::notify(const uint32_t & oldValue, const uint32_t &) { // User changes his address. Remove old IP if (!oldValue) return; -EVENT_LOOP_SINGLETON::GetInstance().Enqueue(traffCnt, &TraffCounterImpl::DelUser, oldValue); +EVENT_LOOP::instance().Enqueue(traffCnt, &TraffCounterImpl::DelUser, oldValue); } //----------------------------------------------------------------------------- inline -void TRF_IP_AFTER::Notify(const uint32_t &, const uint32_t & newValue) +void TRF_IP_AFTER::notify(const uint32_t &, const uint32_t & newValue) { // User changes his address. Add new IP if (!newValue) return; -EVENT_LOOP_SINGLETON::GetInstance().Enqueue(traffCnt, &TraffCounterImpl::AddUser, user); +EVENT_LOOP::instance().Enqueue(traffCnt, &TraffCounterImpl::AddUser, user); } //----------------------------------------------------------------------------- inline -void ADD_USER_NONIFIER::Notify(const UserImplPtr & user) +void ADD_USER_NONIFIER::notify(const UserImplPtr & user) { -EVENT_LOOP_SINGLETON::GetInstance().Enqueue(traffCnt, &TraffCounterImpl::SetUserNotifiers, user); +EVENT_LOOP::instance().Enqueue(traffCnt, &TraffCounterImpl::SetUserNotifiers, user); } //----------------------------------------------------------------------------- inline -void DEL_USER_NONIFIER::Notify(const UserImplPtr & user) +void DEL_USER_NONIFIER::notify(const UserImplPtr & user) { -EVENT_LOOP_SINGLETON::GetInstance().Enqueue(traffCnt, &TraffCounterImpl::UnSetUserNotifiers, user); -EVENT_LOOP_SINGLETON::GetInstance().Enqueue(traffCnt, &TraffCounterImpl::DelUser, user->GetCurrIP()); +EVENT_LOOP::instance().Enqueue(traffCnt, &TraffCounterImpl::UnSetUserNotifiers, user); +EVENT_LOOP::instance().Enqueue(traffCnt, &TraffCounterImpl::DelUser, user->GetCurrIP()); } //----------------------------------------------------------------------------- }