summaryrefslogtreecommitdiffstats
path: root/src/common/pcap.h
blob: fb266e31d190a1dde7ebfe44e0b8d4da5b40aed3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#ifndef __LIBPCAP_H__
#define __LIBPCAP_H__ 

/*
Copyright (c) 2015-2015 Cisco Systems, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/


#include "captureFile.h"
#include <stdio.h>

typedef struct pcaptime {
   uint32_t sec;
   uint32_t msec;
} pcaptime_t;

typedef struct packet_file_header 
{
	uint32_t magic;             
	uint16_t version_major;   
	uint16_t version_minor;   
	uint32_t thiszone;          
	uint32_t sigfigs;           
	uint32_t snaplen;           
	uint32_t linktype;          
}packet_file_header_t ;

typedef struct sf_pkthdr {
	pcaptime_t  ts;         
	uint32_t            caplen;     
	uint32_t            len;        
} sf_pkthdr_t;

/**
 * Implements the CCAPReaderBase interface.
 *
 */
class LibPCapReader : public CCapReaderBase
{
public:
    LibPCapReader();

    virtual ~LibPCapReader();

	/**
     * open file for reading.
     * (can be called once).
	 * @param name
	 * 
	 * @return bool
	 */
    bool Create(char * name, int loops = 0);    

	/**
     * When called after open will return true only if
     * capture file is libpcap format.
	 * 
	 * @return bool
	 */
	bool isValid() { return m_is_valid; }

	/**
     * Fill the structure with the new packet.
	 * @param lpPacket
	 * 
     * @return bool - return true if packet were read and false
     *         otherwise (reached eof)
	 */
	virtual bool ReadPacket(CCapPktRaw *lpPacket); 
        virtual void Rewind();


private:
	LibPCapReader(LibPCapReader &);
	

	bool init();
    void flip(sf_pkthdr_t * tofilp);
	bool m_is_open;
	uint64_t m_last_time;
	bool m_is_valid;
    FILE * m_file_handler;
    bool m_is_flip;

};

/**
 * Libpcap file format writer.
 * Implements CFileWrirerBase interface
 */
class LibPCapWriter: public CFileWriterBase 
{

public:

	LibPCapWriter();
	virtual ~LibPCapWriter();

	/**
     * Open file for writing. Rewrite from scratch (no append).
     * @param name - the file name
	 * 
     * @return bool - return true if File was open successfully.
	 */
	bool Create(char * name);

	/**
     * Write packet to file (must be called only after successfull
     * Create).
     * 
     * @param p  - buffer pointer
     * @param size - buffer length
     * 
     * @return true on success.
	 */
	virtual bool write_packet(CCapPktRaw * lpPacket);
    /**
     * 
     * returns the count of packets so far written
     * 
     * @return uint32_t 
     */
    uint32_t get_pkt_count();

    /**
     * Close file and flush all.
	*/
	void Close();

private:

	bool init();
	FILE * m_file_handler;
	uint64_t m_timestamp;
    bool m_is_open;
    uint32_t m_pkt_count;
};
#endif
n> | resources.libraries.python.Classify.Classify | Library | resources.libraries.python.telemetry.IPFIXSetup | Library | resources.libraries.python.IPv6Setup | Library | resources.libraries.python.Trace | Force Tags | HW_ENV | VM_ENV | 3_NODE_SINGLE_LINK_TOPO | EXPECTED_FAILING | ... | SKIP_VPP_PATCH # TODO: Remove EXPECTED_FAILING tag once functionality is implemented (VPP-204) | Test Setup | Set up functional test | Test Teardown | Tear down functional test | Documentation | *IPFIX ipv6 test cases* | ... | ... | IPFIX tests use 3-node topology TG - DUT1 - DUT2 - TG with | ... | one link between the nodes. DUT1 is configured with IPv4 and IPV6 | ... | routing and static routes. IPFIX is configured on DUT1 with | ... | DUT1->TG interface as collector.Test packets are | ... | sent from TG to or through DUT1. TG listens for flow report packets | ... | and verifies that they contains flow records of test packets sent. *** Variables *** | ${dut1_to_tg_ip}= | 10::10 | ${tg_to_dut1_ip}= | 12::10 | ${prefix_length}= | 64 | ${ip_version}= | ip6 | ${sessions}= | 45 # IPv4 addresses used for IPFIX exporter. Export over IPv6 not (yet?) supported. | ${dut1_to_tg_ip4}= | 192.168.1.1 | ${tg_to_dut1_ip4}= | 192.168.1.2 *** Test Cases *** | TC01: DUT reports packet flow with a large number of packets | | [Documentation] | | ... | [Top] TG-DUT1-DUT2-TG. [Cfg] On DUT1 configure IPFIX with TG interface | | ... | address as collector and add classify session with TG source address. | | ... | [Ver] Make TG send packets to DUT1, then listen for IPFIX template | | ... | and data packets, verify that IPFIX reported the received packets. | | ... | [Ref] RFC 7011 | | Given Configure path in 3-node circular topology | | ... | ${nodes['TG']} | ${nodes['DUT1']} | ${nodes['DUT2']} | ${nodes['TG']} | | And Set interfaces in 3-node circular topology up | | And Set Interface Address | ${dut1_node} | | ... | ${dut1_to_tg} | ${dut1_to_tg_ip} | ${prefix_length} | | And Set Interface Address | ${dut1_node} | | ... | ${dut1_to_tg} | ${dut1_to_tg_ip4} | ${24} | | And Add ARP on DUT | ${dut1_node} | ${dut1_to_tg} | ${tg_to_dut1_ip4} | | ... | ${tg_to_dut1_mac} | | And Add ARP on DUT | ${dut1_node} | ${dut1_to_tg} | ${tg_to_dut1_ip} | | ... | ${tg_to_dut1_mac} | | And VPP RA suppress link layer | ${dut1_node} | ${dut1_to_tg} | | ${table_index} | ${skip_n} | ${match_n}= | | ... | And VPP creates classify table L3 | ${dut1_node} | ${ip_version} | src | | And VPP configures classify session L3 | ${dut1_node} | permit | | ... | ${table_index} | ${skip_n} | ${match_n} | ${ip_version} | src | | ... | ${tg_to_dut1_ip} | | When Assign interface to flow table | ${dut1_node} | ${dut1_to_tg} | | ... | ${table_index} | ip_version=${ip_version} | | And setup IPFIX exporter | ${dut1_node} | ${tg_to_dut1_ip4} | | ... | ${dut1_to_tg_ip4} | interval=5 | | And Set IPFIX stream | ${dut1_node} | ${1} | | And Assign classify table to exporter | ${dut1_node} | ${table_index} | | ... | ${ip_version} | | Then Send packets and verify IPFIX | ${tg_node} | ${dut1_node} | | ... | ${tg_to_dut1} | ${dut1_to_tg} | ${tg_to_dut1_ip} | ${dut1_to_tg_ip} | | ... | count=20000 | timeout=10 | TC02: DUT reports packet flow when multiple sessions are configured | | [Documentation] | | ... | [Top] TG-DUT1-DUT2-TG. [Cfg] On DUT1 configure IPFIX with TG interface | | ... | address as collector and add several classify sessions with different | | ... | ports. | | ... | [Ver] Make TG send packets to DUT1 using a range of ports matching | | ... | configured sessions, then listen for IPFIX template and data packets, | | ... | verify that IPFIX reported the received packets for each session. | | ... | [Ref] RFC 7011 | | Given Configure path in 3-node circular topology | | ... | ${nodes['TG']} | ${nodes['DUT1']} | ${nodes['DUT2']} | ${nodes['TG']} | | And Set interfaces in 3-node circular topology up | | And Set Interface Address | ${dut1_node} | | ... | ${dut1_to_tg} | ${dut1_to_tg_ip} | ${prefix_length} | | And Set Interface Address | ${dut1_node} | | ... | ${dut1_to_tg} | ${dut1_to_tg_ip4} | ${24} | | And Add ARP on DUT | ${dut1_node} | ${dut1_to_tg} | ${tg_to_dut1_ip4} | | ... | ${tg_to_dut1_mac} | | And Add ARP on DUT | ${dut1_node} | ${dut1_to_tg} | ${tg_to_dut1_ip} | | ... | ${tg_to_dut1_mac} | | And VPP RA suppress link layer | ${dut1_node} | ${dut1_to_tg} | | ${table_index} | ${skip_n} | ${match_n}= | | ... | And VPP creates classify table L3 | ${dut1_node} | ${ip_version} | | ... | src proto l4 src_port dst_port | | :FOR | ${index} | IN RANGE | ${sessions} | | | VPP configures classify session generic | ${dut1_node} | | | ... | acl-hit-next permit | ${table_index} | ${skip_n} | ${match_n} | | | ... | l3 ${ip_version} src ${tg_to_dut1_ip} | | | ... | proto 6 l4 src_port ${index} dst_port ${index} | | When Assign interface to flow table | ${dut1_node} | ${dut1_to_tg} | | ... | ${table_index} | ip_version=${ip_version} | | And setup IPFIX exporter | ${dut1_node} | ${tg_to_dut1_ip4} | | ... | ${dut1_to_tg_ip4} | interval=5 | | ... | mtu=1450 | interval=5 | | And Set IPFIX stream | ${dut1_node} | ${1} | | And Assign classify table to exporter | ${dut1_node} | ${table_index} | | ... | ${ip_version} | | Then Send session sweep and verify IPFIX | ${tg_node} | ${dut1_node} | | ... | ${tg_to_dut1} | ${dut1_to_tg} | ${tg_to_dut1_ip} | ${dut1_to_tg_ip} | | ... | ${sessions} | timeout=10 | count=3 # TODO: DUT reports packet flow when ACL is configured with wildcards