X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/a9b057b8c963da58cd4b40ed2cb5cc4b89bc203e..cea081452750a357baae9edf2764dcd4f3b78ca9:/projects/stargazer/plugins/capture/cap_nf/cap_nf.h diff --git a/projects/stargazer/plugins/capture/cap_nf/cap_nf.h b/projects/stargazer/plugins/capture/cap_nf/cap_nf.h index ae0b3763..b9f45c55 100644 --- a/projects/stargazer/plugins/capture/cap_nf/cap_nf.h +++ b/projects/stargazer/plugins/capture/cap_nf/cap_nf.h @@ -27,91 +27,58 @@ $Revision: 1.5 $ $Date: 2009/12/13 12:56:07 $ $Author: faust $ */ -#ifndef __CAP_NF_H__ -#define __CAP_NF_H__ +#pragma once -#include - -#include - -#include "stg/os_int.h" #include "stg/plugin.h" #include "stg/module_settings.h" #include "stg/logger.h" +#include +#include + +#include +#include // close + #define VERSION "cap_nf v. 0.4" #define START_POS 40 #define STOP_POS 40 -class USERS; -class USER; -class TARIFFS; -class ADMINS; -class TRAFFCOUNTER; -class STORE; -class SETTINGS; - -struct NF_HEADER { - uint16_t version; // Protocol version - uint16_t count; // Flows count - uint32_t uptime; // System uptime - uint32_t timestamp; // UNIX timestamp - uint32_t nsecs; // Residual nanoseconds - uint32_t flowSeq; // Sequence counter - uint8_t eType; // Engine type - uint8_t eID; // Engine ID - uint16_t sInterval; // Sampling mode and interval -}; +namespace STG +{ -struct NF_DATA { - uint32_t srcAddr; // Flow source address - uint32_t dstAddr; // Flow destination address - uint32_t nextHop; // IP addres on next hop router - uint16_t inSNMP; // SNMP index of input iface - uint16_t outSNMP; // SNMP index of output iface - uint32_t packets; // Packets in flow - uint32_t octets; // Total number of bytes in flow - uint32_t timeStart; // Uptime on first packet in flow - uint32_t timeFinish;// Uptime on last packet in flow - uint16_t srcPort; // Flow source port - uint16_t dstPort; // Flow destination port - uint8_t pad1; // 1-byte padding - uint8_t TCPFlags; // Cumulative OR of TCP flags - uint8_t proto; // IP protocol type (tcp, udp, etc.) - uint8_t tos; // IP Type of Service (ToS) - uint16_t srcAS; // Source BGP autonomous system number - uint16_t dstAS; // Destination BGP autonomus system number - uint8_t srcMask; // Source address mask in "slash" notation - uint8_t dstMask; // Destination address mask in "slash" notation - uint16_t pad2; // 2-byte padding -}; +struct Users; +struct Tariffs; +struct Admins; +struct TraffCounter; +struct Store; +struct Settings; -#define BUF_SIZE (sizeof(NF_HEADER) + 30 * sizeof(NF_DATA)) +} -class NF_CAP : public PLUGIN { +class NF_CAP : public STG::Plugin { public: NF_CAP(); - ~NF_CAP(); - void SetTraffcounter(TRAFFCOUNTER * tc) { traffCnt = tc; } - void SetSettings(const MODULE_SETTINGS & s) { settings = s; } - int ParseSettings(); + void SetTraffcounter(STG::TraffCounter * tc) override { traffCnt = tc; } + void SetSettings(const STG::ModuleSettings & s) override { settings = s; } + int ParseSettings() override; + + int Start() override; + int Stop() override; + int Reload(const STG::ModuleSettings & /*ms*/) override { return 0; } - int Start(); - int Stop(); - int Reload(const MODULE_SETTINGS & ms) { return 0; } - bool IsRunning() { return runningTCP || runningUDP; } - const std::string & GetStrError() const { return errorStr; } - std::string GetVersion() const { return VERSION; } - uint16_t GetStartPosition() const { return START_POS; } - uint16_t GetStopPosition() const { return STOP_POS; } + bool IsRunning() override { return runningTCP || runningUDP; } + const std::string & GetStrError() const override { return errorStr; } + std::string GetVersion() const override { return VERSION; } + uint16_t GetStartPosition() const override { return START_POS; } + uint16_t GetStopPosition() const override { return STOP_POS; } private: NF_CAP(const NF_CAP & rvalue); NF_CAP & operator=(const NF_CAP & rvalue); - TRAFFCOUNTER * traffCnt; - MODULE_SETTINGS settings; + STG::TraffCounter * traffCnt; + STG::ModuleSettings settings; pthread_t tidTCP; pthread_t tidUDP; bool runningTCP; @@ -123,7 +90,7 @@ private: int sockTCP; int sockUDP; mutable std::string errorStr; - PLUGIN_LOGGER logger; + STG::PluginLogger logger; static void * RunUDP(void *); static void * RunTCP(void *); @@ -134,5 +101,3 @@ private: void CloseTCP() { close(sockTCP); } void CloseUDP() { close(sockUDP); } }; - -#endif