git.stg.codes
/
stg.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Radius. (#8)
[stg.git]
/
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 02452bb87f6e2f8781d3c53323f275c5d1bed20f..097cf3b3fea5241ad641febabed2d1d9a9f3f058 100644
(file)
--- a/
projects/stargazer/plugins/capture/nfqueue/nfqueue.h
+++ b/
projects/stargazer/plugins/capture/nfqueue/nfqueue.h
@@
-18,8
+18,7
@@
* Author : Maxim Mamontov <faust@stargazer.dp.ua>
*/
* 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 "stg/plugin.h"
#include "stg/module_settings.h"
@@
-27,54
+26,65
@@
#include <string>
#include <vector>
#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;
+class Users;
+class 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();
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);
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;
mutable std::string errorStr;
- pthread_t thread;
- bool nonstop;
+ std::jthread m_thread;
bool isRunning;
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;
+};