⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 flow_stat.c

📁 著名的入侵检测系统snort的最新版本的源码
💻 C
字号:
/* $Id$ *//**************************************************************************** * * Copyright (C) 2003-2007 Sourcefire, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License Version 2 as * published by the Free Software Foundation.  You may not use, modify or * distribute this program under any other version of the GNU General * Public License. * * 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. * ****************************************************************************/ #ifdef HAVE_CONFIG_H#include "config.h"#endif#include <string.h>#include "flow.h"#include "flow_cache.h"#include "flow_stat.h"#include "flow_packet.h"/**  * Reinitialize the flowstats *  * @param fsp flowstat pointer *  * @return 0 on success, else failure */int flowstat_clear(FLOWSTATS *fsp){    if(fsp == NULL)    {        return 1;    }    memset(fsp, 0, sizeof(FLOWSTATS));        return 0;}int flowstat_print(FLOWSTATS *fsp){    if(!fsp)    {        return 1;    }             flow_printf("fsp: %p fp: %u lp: %u bs: %u br: %u ps: %u pr: %u flags: %u ft: %x lt: %x ac: %u",                fsp,                (unsigned int) fsp->first_packet,                (unsigned int) fsp->last_packet,                fsp->bytes_sent,                fsp->bytes_recv,                fsp->packets_sent,                fsp->packets_recv,                fsp->flow_flags,                fsp->first_talker,                fsp->last_talker,                fsp->alerts_seen);    return 0;}int flowstat_increment(FLOWSTATS *fsp, int direction, time_t cur, u_int32_t bytes){    switch(direction)    {    case FROM_INITIATOR:        fsp->bytes_sent += bytes;        fsp->packets_sent++;        if(fsp->first_talker == 0)        {            fsp->first_talker = FROM_INITIATOR;            fsp->first_packet = cur;        }        else        {            /* not a typo - only update once */            fsp->last_talker = FROM_INITIATOR;        }                break;    case FROM_RESPONDER:        fsp->bytes_recv += bytes;        fsp->packets_recv++;        fsp->last_talker = FROM_RESPONDER;        break;    default:        flow_printf("flowstat_increment: unable to handle\n");        return -1;    }        fsp->last_packet = cur;                        return 0;}/** * The callback for the flowstats processor* * @param position where in the flow module this is being called from* @param flow the flow that the stats are kept for* @param direction the direction of the flow* @param cur the current time* @param p the current packet (may be NULL)* * @return TBD*/int flowstat_callback(FLOW_POSITION position, FLOW *flowp, int direction,                      time_t cur, FLOWPACKET *p){    int dsize;    switch(position)    {    case FLOW_SHUTDOWN:        /*            flow_printf("flow:");           flowkey_print(&flowp->key);           flowstat_print(&flowp->stats);           flow_printf("\n");        */        break;    case FLOW_NEW:    case FLOW_ADDITIONAL:        if(p)        {            dsize = GetIPv4Len(p);                        flowstat_increment(&flowp->stats, direction, cur, dsize);        }    default:                            case FLOW_FIRST_BIDIRECTIONAL:        break;    }    return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -