mirror of
https://github.com/ntop/ntopng.git
synced 2026-05-20 09:03:24 +00:00
107 lines
3.6 KiB
C++
107 lines
3.6 KiB
C++
/*
|
|
*
|
|
* (C) 2013-25 - ntop.org
|
|
*
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
*/
|
|
|
|
#include "ntop_includes.h"
|
|
|
|
/* ***************************************** */
|
|
|
|
GenericHashEntry::GenericHashEntry(NetworkInterface *_iface) {
|
|
if(trace_new_delete) ntop->getTrace()->traceEvent(TRACE_NORMAL, "[new] %s", __FILE__);
|
|
|
|
hash_next = NULL, iface = _iface, first_seen = last_seen = 0;
|
|
num_uses = 0;
|
|
hash_table = NULL;
|
|
|
|
hash_entry_state = hash_entry_state_active; /* Default for all but Flow */
|
|
|
|
if (iface && iface->getTimeLastPktRcvd() > 0)
|
|
first_seen = last_seen = iface->getTimeLastPktRcvd();
|
|
else
|
|
first_seen = last_seen = time(NULL);
|
|
}
|
|
|
|
/* ***************************************** */
|
|
|
|
GenericHashEntry::~GenericHashEntry() {
|
|
if(trace_new_delete) ntop->getTrace()->traceEvent(TRACE_NORMAL, "[delete] %s", __FILE__);
|
|
}
|
|
|
|
/* ***************************************** */
|
|
|
|
void GenericHashEntry::updateSeen(time_t _last_seen) {
|
|
last_seen = _last_seen;
|
|
|
|
if ((first_seen == 0) || (first_seen > last_seen)) first_seen = last_seen;
|
|
}
|
|
|
|
/* ***************************************** */
|
|
|
|
void GenericHashEntry::updateSeen() { updateSeen(iface->getTimeLastPktRcvd()); }
|
|
|
|
/* ***************************************** */
|
|
|
|
void GenericHashEntry::set_state(HashEntryState s) {
|
|
if ((s < hash_entry_state /* Can't go back */
|
|
|| (s != hash_entry_state + 1 /* Only ahead, one state at time */
|
|
/* Only exception is for flows, which can go from allocated to
|
|
protocoldetected without stepping on not yet detected */
|
|
&& !(hash_entry_state == hash_entry_state_allocated &&
|
|
s == hash_entry_state_flow_protocoldetected))) &&
|
|
(!iface || iface->isRunning()))
|
|
ntop->getTrace()->traceEvent(
|
|
TRACE_ERROR, "Internal error: invalid state transition %d -> %d",
|
|
hash_entry_state, s);
|
|
else
|
|
hash_entry_state = s;
|
|
};
|
|
|
|
/* ***************************************** */
|
|
|
|
void GenericHashEntry::periodic_stats_update(const struct timeval *tv) {
|
|
GenericTrafficElement *elem;
|
|
|
|
if ((elem = dynamic_cast<GenericTrafficElement *>(this)))
|
|
elem->updateStats(tv);
|
|
}
|
|
|
|
/* ***************************************** */
|
|
|
|
bool GenericHashEntry::is_active_entry_now_idle(u_int max_idleness) const {
|
|
bool ret = (((u_int)(iface->getTimeLastPktRcvd()) > (last_seen + max_idleness)) ? true : false);
|
|
|
|
#if 0
|
|
ntop->getTrace()->traceEvent(TRACE_NORMAL, "%s() [lastPkt: %u][last_seen: %u][max_idleness: %u][idle: %s]",
|
|
__FUNCTION__, iface->getTimeLastPktRcvd(), last_seen, max_idleness,
|
|
ret ? "true" : "false");
|
|
#endif
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/* ***************************************** */
|
|
|
|
void GenericHashEntry::getJSONObject(json_object *my_object,
|
|
DetailsLevel details_level) {
|
|
json_object_object_add(my_object, "seen.first",
|
|
json_object_new_int64(first_seen));
|
|
json_object_object_add(my_object, "seen.last",
|
|
json_object_new_int64(last_seen));
|
|
}
|