X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/1acd024a6ba46ab0d9f9c25c089f79a4cba93f25..0907aa4037b12b6b88ee24495d4577a064d4f8db:/projects/stargazer/plugins/capture/nfqueue/nfqueue.h diff --git a/projects/stargazer/plugins/capture/nfqueue/nfqueue.h b/projects/stargazer/plugins/capture/nfqueue/nfqueue.h index 02452bb8..7d71bcd2 100644 --- a/projects/stargazer/plugins/capture/nfqueue/nfqueue.h +++ b/projects/stargazer/plugins/capture/nfqueue/nfqueue.h @@ -18,8 +18,7 @@ * Author : Maxim Mamontov */ -#ifndef NFQ_CAP_H -#define NFQ_CAP_H +#pragma once #include "stg/plugin.h" #include "stg/module_settings.h" @@ -30,33 +29,41 @@ #include -class USERS; -class TARIFFS; -class ADMINS; -class TRAFFCOUNTER; -class SETTINGS; +namespace STG +{ -class TRAFFCOUNTER; +struct Users; +struct Tariffs; +struct Admins; +struct TraffCounter; +struct Settings; +struct RawPacket; -class NFQ_CAP : public PLUGIN { +} + +struct nfq_handle; +struct nfq_q_handle; + +class NFQ_CAP : public STG::Plugin { public: NFQ_CAP(); - virtual ~NFQ_CAP() {} - void SetTraffcounter(TRAFFCOUNTER * tc) { traffCnt = tc; } + void SetTraffcounter(STG::TraffCounter * tc) override { traffCnt = tc; } + + int Start() override; + int Stop() override; + int Reload(const STG::ModuleSettings & /*ms*/) override { return 0; } + bool IsRunning() override { return isRunning; } - int Start(); - int Stop(); - int Reload() { return 0; } - bool IsRunning() { return isRunning; } + void SetSettings(const STG::ModuleSettings & s) override { settings = s; } + int ParseSettings() override; - void SetSettings(const MODULE_SETTINGS & s) { settings = s; } - int ParseSettings(); + const std::string & GetStrError() const override { return errorStr; } + std::string GetVersion() const override; + uint16_t GetStartPosition() const override { return 40; } + uint16_t GetStopPosition() const override { return 40; } - const std::string & GetStrError() const { return errorStr; } - std::string GetVersion() const; - uint16_t GetStartPosition() const { return 40; } - uint16_t GetStopPosition() const { return 40; } + void Process(const STG::RawPacket & packet); private: NFQ_CAP(const NFQ_CAP & rvalue); @@ -69,12 +76,14 @@ private: pthread_t thread; bool nonstop; bool isRunning; - MODULE_SETTINGS settings; + STG::ModuleSettings settings; - TRAFFCOUNTER * traffCnt; + size_t queueNumber; - PLUGIN_LOGGER logger; -}; -//----------------------------------------------------------------------------- + struct nfq_handle * nfqHandle; + struct nfq_q_handle * queueHandle; + + STG::TraffCounter * traffCnt; -#endif + STG::PluginLogger logger; +};