git.stg.codes
/
stg.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use async pool instead of EVENT_LOOP.
[stg.git]
/
projects
/
stargazer
/
plugins
/
capture
/
ether_linux
/
ether_cap.h
diff --git
a/projects/stargazer/plugins/capture/ether_linux/ether_cap.h
b/projects/stargazer/plugins/capture/ether_linux/ether_cap.h
index ed7ba29924e33f7eba522c6d38763019913d67ac..d50923d6572be158c1c713c076338cef04b11f64 100644
(file)
--- a/
projects/stargazer/plugins/capture/ether_linux/ether_cap.h
+++ b/
projects/stargazer/plugins/capture/ether_linux/ether_cap.h
@@
-23,67
+23,63
@@
* Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
*/
* 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/plugin.h"
#include "stg/module_settings.h"
+#include "stg/logger.h"
+
+#include <string>
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wshadow"
+#include <jthread.hpp>
+#pragma GCC diagnostic pop
-class USERS;
-class TARIFFS;
-class ADMINS;
-class TRAFFCOUNTER;
-class SETTINGS;
+namespace STG
+{
-extern "C" PLUGIN * GetPlugin();
+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();
public:
ETHER_CAP();
- virtual ~ETHER_CAP() {}
- void SetUsers(USERS *) {}
- void SetTariffs(TARIFFS *) {}
- void SetAdmins(ADMINS *) {}
- void SetTraffcounter(TRAFFCOUNTER * tc) { traffCnt = tc; }
- void SetStore(STORE *) {}
- void SetStgSettings(const SETTINGS *) {}
+ void SetTraffcounter(STG::TraffCounter * tc) { traffCnt = tc; }
int Start();
int Stop();
int Start();
int Stop();
- int Reload() { return 0; }
+ int Reload(
const STG::ModuleSettings & /*ms*/
) { return 0; }
bool IsRunning() { return isRunning; }
bool IsRunning() { return isRunning; }
- void SetSettings(const MODULE_SETTINGS &) {}
int ParseSettings() { return 0; }
const std::string & GetStrError() const { return errorStr; }
int ParseSettings() { return 0; }
const std::string & GetStrError() const { return errorStr; }
-
const std::string
GetVersion() const;
- uint16_t GetStartPosition() const { return
1
0; }
- uint16_t GetStopPosition() const { return
1
0; }
+
std::string
GetVersion() const;
+ uint16_t GetStartPosition() const { return
4
0; }
+ uint16_t GetStopPosition() const { return
4
0; }
private:
private:
- static void * Run(void *);
+ ETHER_CAP(const ETHER_CAP & rvalue);
+ ETHER_CAP & operator=(const ETHER_CAP & rvalue);
+
+ void Run(std::stop_token token);
int EthCapOpen();
int EthCapClose();
int EthCapRead(void * buffer, int blen, char ** iface);
int EthCapOpen();
int EthCapClose();
int EthCapRead(void * buffer, int blen, char ** iface);
- bool WaitPackets(int sd) const;
mutable std::string errorStr;
mutable std::string errorStr;
- pthread_t thread;
- bool nonstop;
+ std::jthread m_thread;
bool isRunning;
int capSock;
bool isRunning;
int capSock;
- TRAFFCOUNTER * traffCnt;
-};
-//-----------------------------------------------------------------------------
+ STG::TraffCounter * traffCnt;
-#endif
+ STG::PluginLogger logger;
+};