/* * * (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(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)); }