...
Page Properties | ||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Goals
Create a software component implementing capturing command line utility that captures network traffic with the following requirements.
- For SR140 installation, this component utility will be installed optional.
- Only the traffic from and to the machine running SR140 will be captured.
- Only IP traffic will always be captured.
- The basic configurable filtering is available:
- Capture only UDP packets or only TCP packets, or both TCP and UDP (default).
- Capture only packets coming from and to specified list of IP addresses (the other end is always local SR140 host machine)
- Capture only packets coming to or from specific ports on local SR140 machine.
- The resulting output files will be in .pcapng format files. They will be open for view/analysis in optionally. The user will be able to choose whether install it or not.
- The utility will be available for both Windows and Linux.
- The utility will take all configurations from a single configuration file. It will accept only one command line parameter - path to that configuration file.
- Most functionality will be placed into a dynamic library (.dll, .so). The command line executable only contains minimal functionality required to use the library.
- The utility will only capture packets being sent from or received to one of the network interfaces on the host machine, running the utility.
- The utility will only capture UDP and (optionally) TCP packets. Other kinds of IP packets (ARP, ICMP etc.) will be ignored, as well as any non-IP Ethernet packets.
- The utility will save the captured packets in output files in .pcapng format. The resulting files can be opened in the Wireshark UI.
- The resulting files will be of reasonable size. There will be rotation when max size is reached, also when day changes.
...
- have configurable maximum size. Once the size limit is reached on the current file, the next file is created and the utility starts saving packets to the new file.
- There will be limit on maximum number of result files that can reside in the output directory. The oldest files will be deleted as necessary.
- The packet filtering can be configured:
- Set a list of peer IP addresses. Only save traffic between these IP addresses and the capture adapter address.
- Only save packets sent from or received on certain ports on the capture IP interface (local ports).
- Only save packets sent from or received on certain remote ports on peer IPs (remote ports).
Background and strategic fit
For debugging capturingcapture, it has been requested to have the ability to capture network traces from the command line. Customers are not comfortable running Wireshark and they also do not like capturing all network traffic. The request is to be able to capture network traffic from the command line without running the Wireshark GUI. It would be useful to only capture a certain call for debugging call issues but the initial request is to just capture from the command line. Some other customers may want to avoid having network sniffing capacity installed on their network. So the solution should be implemented as an optional component. The user will decide whether to install it or not in the course of the SR140 installation process.
Assumptions
The executable that loads and uses btcap dynamic library capture utility has to be run with elevated permissions. It should be run as local Administrator in Windows. In Linux, it has to be started as root (or sudo). If btcap is loaded into the context of a non-elevated process then Start() entry point will return error.
Requirements
Usage scenario with BTCapHelper
Here is the fragment of using that higher level API:
...
Implementation Overview
...
# | Title | Importance | Notes | ||||||
---|---|---|---|---|---|---|---|---|---|
1 | Capture IP network traffic to/from configured IP interface one of network interfaces on the SR140 machine host | High | |||||||
2 | Save captured traffic to files in .pcapng format compatible with Wireshark | High | 3 | Provide | basic configurable filtering of network trafficHigh | 4 | Provide both Windows and Linux implementation | High | |
53 | Implement as a dynamically loaded library (.so, .dll) plus minimal code using the library | High | |||||||
4 | Read all configuration from a config file. Minimize number of command line parameters | High | |||||||
5 | Ability to Capture UDP traffic | High | |||||||
6 | Ability to Capture TCP traffic (optionally) | High | |||||||
7 | Save captured traffic to files in .pcapng format compatible with Wireshark | High | |||||||
8 | Finalize one .pcapng file when it grows bigger than max configurable size and start the next one on reasonable conditions (max size reached, day changed) | High |
API Design
The capture traffic component is implemented as a dynamic library. Implementing it this way works well for making it optionally installed. The library is named btcap.dll on Windows and btcap.so on Linux. That naming schema appears to be in line with other library names in the problem area (pcap, wincap and so on). The code utilizing btcap library may be placed in a variety of executables including the SR140 server process itself. The executables using btcap library must be running as Administrator (in Window) or root (in Linux).
Important definitions:
- Capture Point. This is defined as one of IP network interfaces available on the host machine PLUS the IP version of packets that we want to capture (IPv4 or IPv6). So, for every NIC installed there can be 2 capture points configured - one for IPv4, and one for IPv6. Capture Point concept is defined simply because the underlying capture technologies require to choose one adapter AND one IP version to setup the packet capture. There will be various ways to identify a Capture Point. The simplest way to point to a particular capture point is to provide a IP address string. Btcap will then understand whether it is IPv4 or IPv6, and then identify the network interface that has the specified IP address. If none of the local IP interfaces have the specified address, then an attempt to start capture will fail.
- Capture Session. This describes the process of capturing network traffic from a single Capture Point. An executable using btcap library may start multiple capture sessions if necessary. With appropriate configuration, some or all of them can capture from the same Capture Point.
- Capture Session Config. This term describes the set of parameters that defines the session. It is primarily defined as a C structure BTCAP_SessionConfig. That structure can be initialized in the code or loaded from a config file. That adds flexibility to the solution. If the code utilizing btcap library is a standalone command line program, it is comfortable to load session config from the file. On the other hand, if that code is part of a bigger system such as SR140 server, it is perhaps easier to fill the config structure from the code. The config file structure is similar to Brooktrout call control config file. Each line follows name=value pattern.
Note: it is possible to extend the above config file format to have multiple sessions configured in one file. Config file could have sections named like this: [wlan0-v6], [eth0-v4], and so on. Each section would hold one session config. Reading such config file would have started all the sessions. Do we need this? Or is it too complicated?
With the terms defined above, the exposed API is very simple. The API is the same for Windows and Linux. There are only a few C-style entry points exported from the library.
int btcap_start(const BTCAP_SessionConfig* config, int* sessionID); // Start Capture Session. Session ID is returned in *sessionID.
int btcap_stop(int sessionID); // Stop Capture Session with sessionID.
int btcap_read_config(const char* configFilePath, BTCAP_SessionConfig* config); // Read config file into the config structure.
All 3 methods return 0 on success or a non-zero error code.
To start a capture session, the user calls btcap_start() providing a pointer to initialized BTCAP_SessionConfig structure. btcap_start() attempts to start the capture session in a separate "capture thread". btcap_start() itself returns as soon as the capture thread successfully starts. If the capture cannot start for whatever reason, then the btcap_start() will return an error code, and the capture thread will not exist upon return. So btcap_start() is not blocking.
To stop a capture session, the user calls btcap_stop() providing the ID of the previously saved session. btcap_stop() signals the capture thread to stop and waits until it is done before returning.
btcap_read_config() API initializes the instance of BTCAP_SessionConfig structure referenced by its 2nd argument with the session config from the file at configFilePath.
Basic Usage Scenario
Here is the basic sequence of operations utilizing the btcap library (in pseudo-code).
---
// Load library and obtain exported entry point pointers by names. If load failed, exit.
// Config file path for this session
const char* configFilePath = ".\btcap.cfg";
// Allocate config structure
BTCAP_SessionConfig cfg = {};
// Optional: Initialize config structure from a config file path obtained/declared earlier. (Alternatively, just initialize all fields from the code).
btcap_read_config(configFilePath, &cfg);
// Start capture session
int sessionID = 0;
btcap_start(&cfg, &sessionID);
// Session started in separate thread. Do other stuff...
// Later stop the capture session
btcap_stop(sessionID);
// Unload the library
-----
Higher level API - BTCapHelper
A higher level API in form of class BTCapHelper was created. It's done mainly to hide the technical details of loading library, and also to hide differences in that area between platforms.
...
one | High | ||
9 | Limit the total number of output files to configurable amount | High | |
10 | Ability to only save traffic between the local IP and a configurable set of remote IPs | High | |
11 | Ability to only save traffic sent from or received on configurable set of local ports | High | |
12 | Ability to only save traffic sent from or received on configurable set of remote ports | High |
Usage
The utility must be given one and only one command line parameter - the path to a configuration file.
In Windows, the user opens command window as Administrator, change directory to where the utility (btcap.exe) is located. Then run:
> .\btcap.exe <path-to-config-file>
In Linux, run:
$ sudo ./btcap <path-to-config-file>
For both platforms, to stop the capture process, the user needs to press Ctrl+C once. In at most a few seconds the utility will gracefully exit. All files and sockets will be closed, any system resources (memory) released.
Btcap Config File
Btcap config file path is the only command line parameter for the capture utility. It defines all configuration parameters. Here is the content of an example configuration file. Each configuration parameter is described by comments.
# capture_ip: Identifier of the network interface to capture traffic. For Windows this MUST be the IPv4 address of the interface. For Linux, this can be
# IPv4 address or IPv6 address of the interface. But the recommended way is to use Linux device name - wlan0, eth0 etc.
# This parameter cannot be missing or empty. There is no default value. '*' is not a valid value for this parameter.
capture_ip = 192.168.5.149
# peer_ip: Capture traffic between these IP addresses and the address specified in capture_ip. The value is a comma-separated list. Each item in the list is an individual IPv4 addresses or an interval of IPv4 addresses. Note: IPv6 addresses are not supported in this parameter.
# Example: peer_ip = 192.168.5.1 - 192.168.5.255, 192.168.7.118 . To capture traffic from ANY IP address, the special value '*' is used: peer_ip = *. Default value is '*'.
# This parameter cannot be empty. If it is missing, the default value will be assigned.
peer_ip= 192.168.5.114, 192.168.5.150 - 192.168.5.200
# tcp_packets: Boolean parameter instructing the tool whether to capture TCP packets (value of 1) or not (value of 0). Default value is 0. NOTE: UDP packets are always captured.
tcp_packets = 1
# local_port_include: Capture packets on these ports on capture_ip interface (local ports). Default value is '*', instructing the system to capture from any local port. This parameter
# cannot be empty. The value is a comma-separated list. Items in the list are either individual port numbers or intervals. Example: local_port_include = 11983, 11984, 21010-21025
local_port_include = 5060, 56000 - 56999
# local_port_exclude: Exclude packets to/from some local ports even if they are included in local_port_include. Default value is empty. The value is a comma-separated list.
# list are individual port numbers or intervals. '*'' is not a valid value for this item. Example: local_port_exclude = 1980,11908,9898-9899
local_port_exclude = 137
# remote_port_include: Capture packets coming to/from these remote ports. Default value is '*', instructing the system to capture allow any remote port. This parameter
# cannot be empty. The value is a comma-separated list. Items in the list are either individual port numbers or intervals. Example: remote_port_include = 11983, 11984, 21010-21025
remote_port_include = *
# remote_port_exclude: Exclude packets from/to some remote ports even if they are included in remote_port_include. Default value is empty. The value is a comma-separated list.
# list are individual port numbers or intervals. '*'' is not a valid value for this item. Example: remote_port_exclude = 1980,11908,9898-9899
remote_port_exclude = 53
# results_dir: The path to a directory (existing) where the pcapng files are saved by this session. Can be absolute path or relative to current directory.
results_dir = ./pcapng/
# max_result_file_size: Maximum pcapng file size before the utility creates and starts writing to the next file. The value is specified in MegaBytes (MB)
max_result_file_size = 100
# max_number_of_result_files: Maximum number of pcapng files that will be written before the system starts to delete oldest files.
max_number_of_result_files = 5
# log_debug: Set to 1 for more verbose logging (debug-level logging). Default is 0.
log_debug = 1
# log_to_console: Set to 1 to print non-critical log messages to console (Note that Errors will always be printed to console, even if this parameter is 0). Default is 0.
log_to_console = 1
Implementation Overview
(to be added...)
End User Installation
The purpose of this tool is to allow the ability of packet capturing on the SR140 system without the need to download any special tools after the installation. The necessary components of this tool will be included with the MSI package. Since there may be customer requirements to not allow packet sniffing tools on their network, and option will be required to allow (for Windows) the end user to not install this tool. The release notes will contain information about this tool and its purpose. The location for instructions for how to use the tool are to be decided. There should be a minimum help from the command line.
Windows InstallShield to be updated to display that the tool will be installed with a check-box enabled on by default to install the tool. Unchecking the box will not install the tool.
The preference is to have the checkbox on the first screen of the installation.
It will be nice to have a switch to control the installation from the command line. The MSI file can be installed with the /passive switch.
For the non-SR140 version of the MSI, this tool will not be available. The installation will not change and the tool will not be included in the MSI.
For Linux, option will be installed by default with no options. It will be up to the end user or application developer to determine if the files should be removed.
The library and executable files will be placed into the bin directory.
A sample filter file will be placed into the config directory.
There will be a sample source file created as an example to use the library as a part of their fax application. This sample will not be included in the installation and will be provided to the application developers when requested.
Need to still determine legal notice and/or if an update to the COO needs to be approved. This tool does not have a dependencies on the SDK and can be created without it. There are no plans to distribute the source files for the tool at this time.
Questions
Below is a list of questions to be addressed as a result of this requirements document:
Question | Outcome |
---|---|
Are packets going to be captured even if they are blocked by a firewall active on the same host? We know Wireshark captures them anyway. We ideally want the same result. Based on the research, that should automatically be the case because of the technologies we used. But need to test explicitly with our code. | |