Public | Automated Build

Last pushed: 10 months ago
Short Description
Automated build of the project on ubuntu 16.04 x86_64.
Full Description

Proxy Manager

The proxy manager is a module that allows you to create TCP/IP proxies. These proxies can be helpful to debug and test network applications. The current implementation use the incredible Boost.Asio library and makes extensive use of asynchronous programming. This allows a better use of the system resources, which allows, for example, run several proxies with only one thread, each proxy managing multiple TCP sessions simultaneously.


During the development of many projects involving networking applications, I realized that proxies are great tools that allow us debug and test the rightness of networking related code, at least at the application layer. With a proxy we can observe the network traffic without need a sniffer (which usually must be run in privileged mode). Besides that, we can simulate extreme scenarios in order to evaluate the robustness of these applications, test timeout scenarios, connection drop and another many cool things.
Over the years I developed a few proxies, mostly using the C language and the Socket API. But, after being presented to the extraordinary Boost.Asio library, I decided it was time to write a new version, simplifying the implementation and enjoying the wonders of the asynchronous paradigm. This project is the result of this work.


If you want to build this project, you must have the following software installed in your system:


  • A modern C++ compiler with support for C++11 features.
  • CMake >= 3.1
  • Boost.Libraries >= 1.55


  • Doxygen (Needed if you want to generate the API reference)
  • Docker (Needed if you want use the dockerized version)


I strongly recommend the use of a shadow build technique in order to keep the source directory clean:

$ mkdir build
$ cd build
$ cmake ${project_dir}
$ make

If everything goes well, you will end up with the module proxy_manager on the root of the build directory. You can check the proxy manager version running:

$ cd ${build_dir}
$ ./proxy_manager --version
version 1.0.0


It is possible to run the proxy manager without install it. But, if you wish, you can install it running:

$ make install

Be aware that you must have the right permissions in order to install the software.


There are two operating modes:

The first mode uses a settings file which is used to initialize the proxy manager. This settings specifies the number of threads used by the thread pool, the logging setup, the list of proxies and so on.
You can get an example of this settings on the ${project_dir}/config/settings.xml.

$ proxy_manager --settings-file=${project_dir}/config/settings.xml

Also, you can use the short form:

$ proxy_manager -s${project_dir}/config/settings.xml

The second mode uses only the program arguments to configure and run only one proxy.

$ proxy_manager --name=http --sport=http-alt --shost= --dport=http --message-dump=ascii --log-level=debug

The example above will route all traffic from the alternative http port (8080) to the http port (80) on All messages will be dumped to the standard output in the ASCII format.

API Reference

The API reference can be built with doxygen. If you have doxygen in your system just run:

$ make doc

At the end of this process, the documentation will be available on:



If you do not have time, or do not want to worry about the tech stuff, you can get a container ready to run here. You can pull the latest image directly from the docker hub running the command:

$ docker pull mapamarco/pm_u16.04

This image was generated with the ${project_dir}/docker/Dockerfile. If you want to build your own image based on this template, run:

$ cd ${project_dir}/docker
$ docker build -t pm_u16.04 .

After pulling a image or build a new one, you can use the proxy interactly:

$ docker run -ti [DOCKER OPTIONS] pm_u16.04 proxy_manager [PROXY MANAGER OPTIONS]


# Forwarding the traffic of the endpoint '' to the endpoint '':
$ docker run -ti --rm -p2222:2222 pm_u16.04 proxy_manager --shost= --sport=2222 --dhost= --dport=22 --name=ssh

# Forwarding the traffic of the endpoint '' to the endpoint '' with hexa dumping of messages:
$ docker run -ti --rm -p2222:2222 pm_u16.04 proxy_manager --shost= --sport=2222 --dhost= --dport=22 --name=ssh --message-dump=hex -ldebug

Using the interactly mode you can see the log messages and stop the proxy using CTRL+C directly on your terminal. But, sometimes we don't need to interact with the program, if this is your case, you can execute the proxy as a daemon using the option -d:

$ docker run -ti pm_u16.04 proxy_manager [OPTIONS]


  • Multiples proxies per instance
  • IPv4 and IPv6 sockets
  • Asynchronous approach
  • Configurable logging system
  • Dump of messages (hexadecimal or ascii)
  • Configurable buffer sizes
  • Configurable message delays (client and server)
  • Thread pool


  • UDP sockets
  • Add plugin support
  • Improve the connection drop (timeout)
  • Man page
  • Improve the documentation with UML diagrams
  • Improve the API reference
  • Improve this README
  • Add more examples
  • Bandwidth management


This software is distributed under the Boost Software License, Version 1.0.
You can get a copy here.

Docker Pull Command
Source Repository