Ptero is a CLI text steganography tool, meant to be used in the social media like Facebook. It offers a way to encode and decode data.
It implements the algorithm presented here.
However, it also includes an extended implementation of specified algorithm, called ELUV. See help
of the tool for more info on the usage.
The tool was tested in Facebook's Messenger and Twitter - both methods were working correctly. You can also read more about the method here.
The ptero-cli
is multiplatform program - it works on Linux, Windows and macOS (tested on Catalina, currently there are no pre-built binaries). If you want to try out the ptero-cli
you have two options:
One is to download pre-compiled binaries from Github release section. Currently, there are only two versions AMD64 for Linux distributions and Windows.
If for any reason you are not able to use them you can try out the second option.
The second option is to install the ptero-cli
using cargo
. This will build the binary according to your OS and architecture. Simply run:
cargo install ptero-cli
This will install the newest version from Crates.io. Of course, you can always built it by yourself by cloning this repository and running:
cargo build --release
The built binary will be available at target/release/
.
Rust is the main language used in this repository. By default, you have to install standard Rust toolchain to start working. See official installation page for more info.
I use the VS Code as the main editor in this project. I'd suggest to install these extensions:
If you want to just build the artifact run:
cargo build
To run the binary through the cargo
you can issue:
# Example with argument
cargo run -- -vv encode -c some_cover_text -d secret
To run all the tests:
cargo test
Coverage checking is done through separate package cargo-tarpaulin
- make sure to install it if you want to. To run it locally just (more or less the same command is run on Github Actions):
cargo tarpaulin -v --exclude-files src/log.rs --force-clean
This project ensures it is compliant with clippy
rules. To make sure you're fine, run:
cargo clippy
This project contains both binary package nad library. See lib.rs to see module overview and main.rs the entry point for CLI binary package.
There are two script in the scripts directory which are used for measuring the bitrate. The one is bitrate_for_pivot.sh which calculates the average bitrate for given amount of executions on random secret data, and the other one measure_bitrate.sh does launch measurements for given pivot range in parallel, 100 executions and 30 bytes secret data.
The latter one should be used to get the results. For example:
./scripts/measure_bitrate.sh 10 40 &> result
It should be ran in the project root. Please note that there might be a case that given secret may not be embedded in cover text due to the cover text capacity.