* Author : Maxim Mamontov <faust@stargazer.dp.ua>
*/
-#ifndef NFQ_CAP_H
-#define NFQ_CAP_H
+#pragma once
#include "stg/plugin.h"
#include "stg/module_settings.h"
#include <string>
#include <vector>
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wshadow"
+#include <jthread.hpp>
+#pragma GCC diagnostic pop
-#include <pthread.h>
+namespace STG
+{
-class USERS;
-class TARIFFS;
-class ADMINS;
-class TRAFFCOUNTER;
-class SETTINGS;
+struct Users;
+struct Tariffs;
+struct Admins;
+struct TraffCounter;
+struct Settings;
+struct RawPacket;
-class TRAFFCOUNTER;
+}
-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);
NFQ_CAP & operator=(const NFQ_CAP & rvalue);
- static void * Run(void *);
+ void Run(std::stop_token token);
mutable std::string errorStr;
- pthread_t thread;
- bool nonstop;
+ std::jthread m_thread;
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;
-#endif
+ STG::TraffCounter * traffCnt;
+
+ STG::PluginLogger logger;
+};