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

📄 libnet_build_ospf.c

📁 tcp数据流重放工具
💻 C
📖 第 1 页 / 共 2 页
字号:
/* *  $Id: libnet_build_ospf.c,v 1.6 2003/09/23 22:36:55 mike Exp $ * *  libnet *  libnet_build_ospf.c - OSPF packet assembler * *  Copyright (c) 1998 - 2003 Mike D. Schiffman <mike@infonexus.com> *  All rights reserved. * *  Copyright (c) 1999, 2000 Andrew Reiter <areiter@bindview.com> *  Bindview Development * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * */#if (HAVE_CONFIG_H)#include "../include/config.h"#endif#if (!(_WIN32) || (__CYGWIN__)) 
#include "../include/libnet.h"
#else
#include "../include/win32/libnet.h"
#endiflibnet_ptag_tlibnet_build_ospfv2(u_int16_t len, u_int8_t type, u_int32_t rtr_id, u_int32_t area_id,            u_int16_t sum, u_int16_t autype, u_int8_t *payload, u_int32_t payload_s,             libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_ospf_hdr ospf_hdr;    if (l == NULL)    {         return (-1);    }      n = LIBNET_OSPF_H + payload_s;    h = LIBNET_OSPF_H + payload_s + len;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_H);    if (p == NULL)    {        return (-1);    }    	memset(&ospf_hdr, 0, sizeof(ospf_hdr));	ospf_hdr.ospf_v               = 2;              /* OSPF version 2 */    ospf_hdr.ospf_type            = type;           /* Type of pkt */    ospf_hdr.ospf_len             = htons(h);       /* Pkt len */    ospf_hdr.ospf_rtr_id.s_addr   = htonl(rtr_id);  /* Router ID */    ospf_hdr.ospf_area_id.s_addr  = htonl(area_id); /* Area ID */    ospf_hdr.ospf_cksum           = sum;    ospf_hdr.ospf_auth_type       = htons(autype);  /* Type of auth */    n = libnet_pblock_append(l, p, (u_int8_t *)&ospf_hdr, LIBNET_OSPF_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    if (sum == 0)    {        /*         *  If checksum is zero, by default libnet will compute a checksum         *  for the user.  The programmer can override this by calling         *  libnet_toggle_checksum(l, ptag, 1);         */        libnet_pblock_setflags(p, LIBNET_PBLOCK_DO_CHECKSUM);    }    return (ptag ? ptag : libnet_pblock_update(l, p, h, LIBNET_PBLOCK_OSPF_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_hello(u_int32_t netmask, u_int16_t interval, u_int8_t opts,             u_int8_t priority, u_int dead_int, u_int32_t des_rtr, u_int32_t bkup_rtr,            u_int32_t neighbor, u_int8_t *payload, u_int32_t payload_s, libnet_t *l,            libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_ospf_hello_hdr hello_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_HELLO_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_HELLO_H);    if (p == NULL)    {        return (-1);    }    	memset(&hello_hdr, 0, sizeof(hello_hdr));	hello_hdr.hello_nmask.s_addr    = htonl(netmask);  /* Netmask */    hello_hdr.hello_intrvl          = htons(interval);	/* # seconds since last packet sent */    hello_hdr.hello_opts            = opts;     /* OSPF_* options */    hello_hdr.hello_rtr_pri         = priority; /* If 0, can't be backup */    hello_hdr.hello_dead_intvl      = htonl(dead_int); /* Time til router is deemed down */    hello_hdr.hello_des_rtr.s_addr  = htonl(des_rtr);	/* Networks designated router */    hello_hdr.hello_bkup_rtr.s_addr = htonl(bkup_rtr); /* Networks backup router */    hello_hdr.hello_nbr.s_addr      = htonl(neighbor);    n = libnet_pblock_append(l, p, (u_int8_t *)&hello_hdr, LIBNET_OSPF_HELLO_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }     return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_OSPF_HELLO_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_dbd(u_int16_t dgram_len, u_int8_t opts, u_int8_t type,            u_int seqnum, u_int8_t *payload, u_int32_t payload_s, libnet_t *l,            libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_dbd_hdr dbd_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_DBD_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_DBD_H);    if (p == NULL)    {        return (-1);    }    	memset(&dbd_hdr, 0, sizeof(dbd_hdr));    dbd_hdr.dbd_mtu_len	= htons(dgram_len); /* Max length of IP packet IF can use */    dbd_hdr.dbd_opts    = opts;	            /* OSPF_* options */    dbd_hdr.dbd_type    = type;	            /* Type of exchange occuring */    dbd_hdr.dbd_seq     = htonl(seqnum);    /* DBD sequence number */    n = libnet_pblock_append(l, p, (u_int8_t *)&dbd_hdr, LIBNET_OSPF_DBD_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;         }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_OSPF_DBD_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsr(u_int type, u_int lsid, u_int32_t advrtr, u_int8_t *payload,            u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_lsr_hdr lsr_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LSR_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_LSR_H);    if (p == NULL)    {        return (-1);    }	memset(&lsr_hdr, 0, sizeof(lsr_hdr));	lsr_hdr.lsr_type         = htonl(type);     /* Type of LS being requested */    lsr_hdr.lsr_lsid	     = htonl(lsid);     /* Link State ID */    lsr_hdr.lsr_adrtr.s_addr = htonl(advrtr);   /* Advertising router */    n = libnet_pblock_append(l, p, (u_int8_t *)&lsr_hdr, LIBNET_OSPF_LSR_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_OSPF_LSR_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsu(u_int num, u_int8_t *payload, u_int32_t payload_s,            libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_lsu_hdr lh_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LSU_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_LSU_H);    if (p == NULL)    {        return (-1);    }	memset(&lh_hdr, 0, sizeof(lh_hdr));	lh_hdr.lsu_num = htonl(num);   /* Number of LSAs that will be bcasted */    n = libnet_pblock_append(l, p, (u_int8_t *)&lh_hdr, LIBNET_OSPF_LSU_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,

⌨️ 快捷键说明

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