* Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
*/
-#ifndef ETHER_CAP_H
-#define ETHER_CAP_H
+#pragma once
-#include <pthread.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
-#include "base_plugin.h"
-#include "base_settings.h"
-#include "../../../traffcounter.h"
+namespace STG
+{
-using namespace std;
+struct Users;
+struct Tariffs;
+struct Admins;
+struct TraffCounter;
+struct Settings;
-extern "C" BASE_PLUGIN * GetPlugin();
+}
//-----------------------------------------------------------------------------
-class ETHER_CAP :public BASE_PLUGIN
-{
+class ETHER_CAP : public STG::Plugin {
public:
ETHER_CAP();
- virtual ~ETHER_CAP(){};
- void SetUsers(USERS *){};
- void SetTariffs(TARIFFS *){};
- void SetAdmins(ADMINS *){};
- void SetTraffcounter(TRAFFCOUNTER * tc);
- void SetStore(BASE_STORE *){};
- void SetStgSettings(const SETTINGS *){};
+ void SetTraffcounter(STG::TraffCounter * tc) { traffCnt = tc; }
int Start();
int Stop();
- int Reload() { return 0; };
- bool IsRunning();
+ int Reload(const STG::ModuleSettings & /*ms*/) { return 0; }
+ bool IsRunning() { return isRunning; }
- void SetSettings(const MODULE_SETTINGS &){};
- int ParseSettings(){ return 0; };
- const string & GetStrError() const;
- const string GetVersion() const;
- uint16_t GetStartPosition() const;
- uint16_t GetStopPosition() const;
+ int ParseSettings() { return 0; }
+ const std::string & GetStrError() const { return errorStr; }
+ std::string GetVersion() const;
+ uint16_t GetStartPosition() const { return 40; }
+ uint16_t GetStopPosition() const { return 40; }
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);
- bool WaitPackets(int sd) const;
- mutable string errorStr;
+ mutable std::string errorStr;
- pthread_t thread;
- bool nonstop;
+ std::jthread m_thread;
bool isRunning;
int capSock;
- TRAFFCOUNTER * traffCnt;
-};
-//-----------------------------------------------------------------------------
-
-#endif //ETHER_CAP_H
+ STG::TraffCounter * traffCnt;
+ STG::PluginLogger logger;
+};