What happens if a traceroute with the same TTL/hop limit is received from two different source addresses? How will they react?

Marek Küthe 9d2c85a951 Add CodeScene badge 10 mēneši atpakaļ
.github d8628facff Add coverage reports for CodeScene 10 mēneši atpakaļ
.woodpecker 86b57dbc6b Do not upload debug symbols in release 10 mēneši atpakaļ
debian 33fb64f3df Add new release 10 mēneši atpakaļ
src 9ed671a216 Add more tests 10 mēneši atpakaļ
systemd 3d42acfbde Add systemd unit 10 mēneši atpakaļ
tests 094a724c5e Change test to cover more code 10 mēneši atpakaļ
.clang-format bac59b75ac Improve style 10 mēneši atpakaļ
.clang-format-include c3bf0e0bb3 Add more tests 10 mēneši atpakaļ
.clang-tidy b95fd4c31a Improve style 10 mēneši atpakaļ
.deepsource.toml d8628facff Add coverage reports for CodeScene 10 mēneši atpakaļ
.gitignore c8f7f100d0 Update debian package 10 mēneši atpakaļ
BUILDING.md a6be8bbdfd Improve building documentation 10 mēneši atpakaļ
CHANGELOG.md 6ef9597927 Improve style 10 mēneši atpakaļ
CONTRIBUTING.md 393fbcd6e4 Add CONTRIBUTING.md 10 mēneši atpakaļ
LICENSE a451b0c588 Initial commit 11 mēneši atpakaļ
Makefile dc210a2436 Add coverage target in Makefile 10 mēneši atpakaļ
README.md 9d2c85a951 Add CodeScene badge 10 mēneši atpakaļ
SECURITY.md 33fb64f3df Add new release 10 mēneši atpakaļ
meson.build 571eb3092c Add loglevel test 10 mēneši atpakaļ
meson_options.txt 3d42acfbde Add systemd unit 10 mēneši atpakaļ
sonar-project.properties 858e1812ae Add SonarCloud 10 mēneši atpakaļ
topology.drawio 1dd36e15d1 Update README 10 mēneši atpakaļ
topology.png 1dd36e15d1 Update README 10 mēneši atpakaļ

README.md

Crazy traceroute

pipeline badge OpenSSF Best Practices Codacy Badge Coverity Badge Quality Gate Status DeepSource CodeScene Code Health codecov CodeFactor

What happens if a traceroute with the same TTL/hop limit is received from two different source addresses? How will they react?

crazytrace is a network simulation program that can be used to see how different ping and traceroute implementations react when the sender address is different than expected.

And what the hell does crazytrace do now? Simply explained.

When a network packet is used, it passes through several devices (also known as routers) on its journey to its destination. There are "traceroute" programs to determine these devices and thus the path that the packet takes. These usually query the path several times. What would happen if a certain device has two addresses on this path with which it responds? To see how the programs behave in this case, crazytrace simulates such a device (or several, depending on the configuration). This is achieved by creating a virtual Ethernet adapter behind which the simulated device or the simulated devices are located.

Building

See BUILDING.md.

Contributing

See CONTRIBUTING.md.

Security

See SECURITY.md.

How it works?

crazytrace uses several libraries and tricks to create a virtual TAP adapter behind which the simulated network is hidden.

  • libtuntap: This library is used to create and close the TAP device.
  • libtins: This library is used for packet parsing and crafting.
  • yaml-cpp: This library is used to read the configuration file in YAML format.
  • Boost.log: This library is used as a logger. Various log levels can be set in the configuration file.
  • Boost.Asio: This library is used to communicate with the socket of the TAP device and to receive and send several packets simultaneously (asynchronously).

Here is how the program works:

  1. reading the configuration file
  2. setting the log level
  3. output of the libtuntap version
  4. output of the configuration
  5. creation of the TAP device
  6. initialization of the network simulator
  7. starting the network simulator

The following is how the network simulator works when a packet is received:

  1. reading the packet with tins
  2. reading the packet into a NodeRequest
  3. generate a NodeReply using the configuration
  4. check whether a reply should be sent 4a. If no, abort
  5. if yes, create a NodeReply package using libtins
  6. write the packet to the socket of the TAP device

Configuration file

The following is a example configuration file:

---
log_level: info
device_name: crazytrace
post_up_commands:
  - ip route add fd00::/64 dev crazytrace via fe80::b1:4fff:fe7e:9dc3
nodes:
  - mac: 02:B1:4F:7E:9D:C3
    addresses: [fe80::b1:4fff:fe7e:9dc3]
    hoplimit: 255
    nodes:
      - addresses: [fd00::1]
        nodes:
          - addresses: [fd00::21, fd00::22, fd00::23]
            nodes:
              - addresses: [fd00::3]
  - mac: 02:B1:4F:7E:9D:C4
    addresses: [fe80::b1:4fff:fe7e:9dc4]

This would generate the following topology: Topology

The log level can have one of the following values:

  • trace
  • debug
  • info
  • warning
  • error
  • fatal

For production, info or lower is empheolen.

The device name is the name of the TAP interface that crazytrace creates.

The post-up commands are a series of commands that are executed by the command processor of the operating system after the TAP interface has been created. These commands are executed with the same rights as crazytrace. They receive no input. Their output is ignored. crazytrace aborts if one of the commands has not been successfully completed.

A list of nodes then appears in the configuration file. These can have the following attributes:

  • mac: The nodes in the first level must have a MAC address. crazytrace acts as if these nodes were directly on the TAP interface. All child nodes of these are behind them, so that no MAC address is required for communication.
  • addresses: A list of IP addresses that the node should have. It responds to all of them and replies with a random one.
  • hoplimit: Hop limit with which the response is to be sent. ICMP NDP packets are always sent with a hop limit of 255. If no hop limit is specified, a hop limit of 64 is used.
  • nodes: A list of nodes (which are structured in the same way) which are behind the current one in the simulated network.

The configuration is written in YAML.

Which MAC addresses can I use without any problems?

The following belong to the locally administered range and can be used without any problems:

x2-xx-xx-xx-xx-xx
x6-xx-xx-xx-xx-xx
xA-xx-xx-xx-xx-xx
xE-xx-xx-xx-xx-xx

How do I start crazytrace?

crazytrace is configured via a configuration file. The path to this file is given as the first (and only) argument.

# /path/to/crazytrace /path/to/config.yaml

Notes for myself

Create a new release

To create a new release the following is necessary:

  • Create a changelog entry
  • Create a changelog entry for the Debian package
  • Update the SECURITY.md
  • Create a new git tag