mirror of
https://github.com/mfontanini/libtins
synced 2026-01-30 13:34:27 +01:00
Change tcp_ip directory structure
This commit is contained in:
@@ -5,3 +5,4 @@ INSTALL(
|
||||
COMPONENT Headers
|
||||
)
|
||||
ADD_SUBDIRECTORY(dot11)
|
||||
ADD_SUBDIRECTORY(tcp_ip)
|
||||
|
||||
6
include/tins/tcp_ip/CMakeLists.txt
Normal file
6
include/tins/tcp_ip/CMakeLists.txt
Normal file
@@ -0,0 +1,6 @@
|
||||
FILE(GLOB INCLUDE_FILES "*.h")
|
||||
INSTALL(
|
||||
FILES ${INCLUDE_FILES}
|
||||
DESTINATION include/tins/tcp_ip
|
||||
COMPONENT Headers
|
||||
)
|
||||
@@ -27,10 +27,10 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef TINS_TCP_IP_H
|
||||
#define TINS_TCP_IP_H
|
||||
#ifndef TINS_TCP_IP_STREAM_H
|
||||
#define TINS_TCP_IP_STREAM_H
|
||||
|
||||
#include "cxxstd.h"
|
||||
#include "../cxxstd.h"
|
||||
|
||||
// This classes use C++11 features
|
||||
#if TINS_IS_CXX11
|
||||
@@ -40,8 +40,8 @@
|
||||
#include <map>
|
||||
#include <functional>
|
||||
#include <stdint.h>
|
||||
#include "macros.h"
|
||||
#include "hw_address.h"
|
||||
#include "../macros.h"
|
||||
#include "../hw_address.h"
|
||||
|
||||
namespace Tins {
|
||||
|
||||
@@ -541,122 +541,9 @@ private:
|
||||
bool auto_cleanup_;
|
||||
};
|
||||
|
||||
/**
|
||||
* \brief Represents a class that follows TCP and reassembles streams
|
||||
*
|
||||
* This class processes packets and whenever it detects a new connection
|
||||
* being open, it starts tracking it. This will follow all data sent by
|
||||
* each peer and make it available to the user in a simple way.
|
||||
*
|
||||
* In order to use this class, just create an instance and set the
|
||||
* new stream callback to some function that you want:
|
||||
*
|
||||
* \code
|
||||
* void on_new_stream(TCPStream& stream) {
|
||||
* // Do something with it.
|
||||
* // This is the perfect time to set the stream's client/server
|
||||
* // write callbacks so you are notified whenever there's new
|
||||
* // data on the stream
|
||||
* }
|
||||
*
|
||||
* // Create it
|
||||
* StreamFollower follower;
|
||||
* // Set the callback
|
||||
* follower.new_stream_callback(&on_new_stream);
|
||||
* \endcode
|
||||
*/
|
||||
class TINS_API StreamFollower {
|
||||
public:
|
||||
/**
|
||||
* \brief The type used for callbacks
|
||||
*/
|
||||
typedef Stream::stream_callback_type stream_callback_type;
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
StreamFollower();
|
||||
|
||||
/**
|
||||
* \brief Processes a packet
|
||||
*
|
||||
* This will detect if this packet belongs to an existing stream
|
||||
* and process it, or if it belongs to a new one, in which case it
|
||||
* starts tracking it.
|
||||
*
|
||||
* This method always returns true so it can be easily plugged as
|
||||
* the argument to Sniffer::sniff_loop.
|
||||
*
|
||||
* \param packet The packet to be processed
|
||||
* \return Always true
|
||||
*/
|
||||
bool process_packet(PDU& packet);
|
||||
|
||||
/**
|
||||
* \brief Sets the callback to be executed when a new stream is captured.
|
||||
*
|
||||
* Whenever a new stream is captured, the provided callback will be
|
||||
* executed.
|
||||
*
|
||||
* \param callback The callback to be set
|
||||
*/
|
||||
void new_stream_callback(const stream_callback_type& callback);
|
||||
|
||||
/**
|
||||
* Finds the stream identified by the provided arguments.
|
||||
*
|
||||
* \param client_addr The client's address
|
||||
* \param client_port The client's port
|
||||
* \param server_addr The server's address
|
||||
* \param server_addr The server's port
|
||||
*/
|
||||
Stream& find_stream(IPv4Address client_addr, uint16_t client_port,
|
||||
IPv4Address server_addr, uint16_t server_port);
|
||||
|
||||
/**
|
||||
* Finds the stream identified by the provided arguments.
|
||||
*
|
||||
* \param client_addr The client's address
|
||||
* \param client_port The client's port
|
||||
* \param server_addr The server's address
|
||||
* \param server_addr The server's port
|
||||
*/
|
||||
Stream& find_stream(IPv6Address client_addr, uint16_t client_port,
|
||||
IPv6Address server_addr, uint16_t server_port);
|
||||
private:
|
||||
static const size_t DEFAULT_MAX_BUFFERED_CHUNKS;
|
||||
typedef std::array<uint8_t, 16> address_type;
|
||||
|
||||
struct stream_id {
|
||||
stream_id(const address_type& client_addr, uint16_t client_port,
|
||||
const address_type& server_addr, uint16_t server_port);
|
||||
|
||||
address_type min_address;
|
||||
address_type max_address;
|
||||
uint16_t min_address_port;
|
||||
uint16_t max_address_port;
|
||||
|
||||
bool operator<(const stream_id& rhs) const;
|
||||
|
||||
static size_t hash(const stream_id& id);
|
||||
};
|
||||
|
||||
typedef std::map<stream_id, Stream> streams_type;
|
||||
|
||||
stream_id make_stream_id(const PDU& packet);
|
||||
Stream& find_stream(const stream_id& id);
|
||||
static address_type serialize(IPv4Address address);
|
||||
static address_type serialize(const IPv6Address& address);
|
||||
|
||||
streams_type streams_;
|
||||
stream_callback_type on_new_connection_;
|
||||
size_t max_buffered_chunks_;
|
||||
bool attach_to_flows_;
|
||||
};
|
||||
|
||||
} // TCPIP
|
||||
} // Tins
|
||||
|
||||
#endif // TINS_IS_CXX11
|
||||
|
||||
#endif // TINS_TCP_IP_H
|
||||
#endif // TINS_TCP_IP_STREAM_H
|
||||
168
include/tins/tcp_ip/stream_follower.h
Normal file
168
include/tins/tcp_ip/stream_follower.h
Normal file
@@ -0,0 +1,168 @@
|
||||
/*
|
||||
* Copyright (c) 2016, Matias Fontanini
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are
|
||||
* met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * 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 COPYRIGHT HOLDERS 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 COPYRIGHT
|
||||
* OWNER 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.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef TINS_TCP_IP_STREAM_FOLLOWER_H
|
||||
#define TINS_TCP_IP_STREAM_FOLLOWER_H
|
||||
|
||||
#include "../cxxstd.h"
|
||||
|
||||
// This classes use C++11 features
|
||||
#if TINS_IS_CXX11
|
||||
|
||||
#include <map>
|
||||
#include "stream.h"
|
||||
|
||||
namespace Tins {
|
||||
|
||||
class PDU;
|
||||
class TCP;
|
||||
class IPv4Address;
|
||||
class IPv6Address;
|
||||
|
||||
namespace TCPIP {
|
||||
|
||||
/**
|
||||
* \brief Represents a class that follows TCP and reassembles streams
|
||||
*
|
||||
* This class processes packets and whenever it detects a new connection
|
||||
* being open, it starts tracking it. This will follow all data sent by
|
||||
* each peer and make it available to the user in a simple way.
|
||||
*
|
||||
* In order to use this class, just create an instance and set the
|
||||
* new stream callback to some function that you want:
|
||||
*
|
||||
* \code
|
||||
* void on_new_stream(TCPStream& stream) {
|
||||
* // Do something with it.
|
||||
* // This is the perfect time to set the stream's client/server
|
||||
* // write callbacks so you are notified whenever there's new
|
||||
* // data on the stream
|
||||
* }
|
||||
*
|
||||
* // Create it
|
||||
* StreamFollower follower;
|
||||
* // Set the callback
|
||||
* follower.new_stream_callback(&on_new_stream);
|
||||
* \endcode
|
||||
*/
|
||||
class TINS_API StreamFollower {
|
||||
public:
|
||||
/**
|
||||
* \brief The type used for callbacks
|
||||
*/
|
||||
typedef Stream::stream_callback_type stream_callback_type;
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
StreamFollower();
|
||||
|
||||
/**
|
||||
* \brief Processes a packet
|
||||
*
|
||||
* This will detect if this packet belongs to an existing stream
|
||||
* and process it, or if it belongs to a new one, in which case it
|
||||
* starts tracking it.
|
||||
*
|
||||
* This method always returns true so it can be easily plugged as
|
||||
* the argument to Sniffer::sniff_loop.
|
||||
*
|
||||
* \param packet The packet to be processed
|
||||
* \return Always true
|
||||
*/
|
||||
bool process_packet(PDU& packet);
|
||||
|
||||
/**
|
||||
* \brief Sets the callback to be executed when a new stream is captured.
|
||||
*
|
||||
* Whenever a new stream is captured, the provided callback will be
|
||||
* executed.
|
||||
*
|
||||
* \param callback The callback to be set
|
||||
*/
|
||||
void new_stream_callback(const stream_callback_type& callback);
|
||||
|
||||
/**
|
||||
* Finds the stream identified by the provided arguments.
|
||||
*
|
||||
* \param client_addr The client's address
|
||||
* \param client_port The client's port
|
||||
* \param server_addr The server's address
|
||||
* \param server_addr The server's port
|
||||
*/
|
||||
Stream& find_stream(IPv4Address client_addr, uint16_t client_port,
|
||||
IPv4Address server_addr, uint16_t server_port);
|
||||
|
||||
/**
|
||||
* Finds the stream identified by the provided arguments.
|
||||
*
|
||||
* \param client_addr The client's address
|
||||
* \param client_port The client's port
|
||||
* \param server_addr The server's address
|
||||
* \param server_addr The server's port
|
||||
*/
|
||||
Stream& find_stream(IPv6Address client_addr, uint16_t client_port,
|
||||
IPv6Address server_addr, uint16_t server_port);
|
||||
private:
|
||||
static const size_t DEFAULT_MAX_BUFFERED_CHUNKS;
|
||||
typedef std::array<uint8_t, 16> address_type;
|
||||
|
||||
struct stream_id {
|
||||
stream_id(const address_type& client_addr, uint16_t client_port,
|
||||
const address_type& server_addr, uint16_t server_port);
|
||||
|
||||
address_type min_address;
|
||||
address_type max_address;
|
||||
uint16_t min_address_port;
|
||||
uint16_t max_address_port;
|
||||
|
||||
bool operator<(const stream_id& rhs) const;
|
||||
|
||||
static size_t hash(const stream_id& id);
|
||||
};
|
||||
|
||||
typedef std::map<stream_id, Stream> streams_type;
|
||||
|
||||
stream_id make_stream_id(const PDU& packet);
|
||||
Stream& find_stream(const stream_id& id);
|
||||
static address_type serialize(IPv4Address address);
|
||||
static address_type serialize(const IPv6Address& address);
|
||||
|
||||
streams_type streams_;
|
||||
stream_callback_type on_new_connection_;
|
||||
size_t max_buffered_chunks_;
|
||||
bool attach_to_flows_;
|
||||
};
|
||||
|
||||
} // TCPIP
|
||||
} // Tins
|
||||
|
||||
#endif // TINS_IS_CXX11
|
||||
|
||||
#endif // TINS_TCP_IP_STREAM_FOLLOWER_H
|
||||
Reference in New Issue
Block a user