#ldap #tokio #bloodhound #async #pentest #zip-archive

bin+lib rusthound-ce

Active Directory data collector for Bloodhound Community Edition written in rust

10 stable releases

new 2.3.2 Jan 14, 2025
2.3.1 Jan 5, 2025
2.3.0 Dec 28, 2024
2.1.1 Oct 24, 2024

#1009 in Network programming

Download history 144/week @ 2024-10-17 157/week @ 2024-10-24 4/week @ 2024-10-31 1/week @ 2024-11-14 132/week @ 2024-11-28 31/week @ 2024-12-05 17/week @ 2024-12-12 462/week @ 2024-12-19 145/week @ 2024-12-26 143/week @ 2025-01-02 116/week @ 2025-01-09

869 downloads per month

MIT license

560KB
10K SLoC

rusthound-ce logo


RustHound-CE is a cross-platform and cross-compiled BloodHound collector tool written in Rust, making it compatible with Linux, Windows, and macOS. It therefore generates all the JSON files that can be analyzed by BloodHound Community Edition. This version is only compatible with BloodHound Community Edition. The version compatible with BloodHound Legacy can be found on NeverHack's github.

RustHound was created during my years as a pentester at Armature Technologies, renamed later Opencyber then NeverHack. I would like to thanks NeverHack for giving me time to research and develop the original RustHound project, which is still available on their github. We've decided to continue working together to contribute to both versions. This one will remain compatible with the community edition, and the NeverHack version with the Legacy version of BloodHound.

Quick usage

Compilation

This project can be compiled directly from make command like:

# Compile it for your current system
make release
# Compile it for Windows
make windows

Or using docker like below:

docker build --rm -t rusthound-ce .

# Then
docker run --rm -v $PWD:/usr/src/rusthound-ce rusthound-ce help
docker run --rm -v $PWD:/usr/src/rusthound-ce rusthound-ce release
docker run --rm -v $PWD:/usr/src/rusthound-ce rusthound-ce windows
docker run --rm -v $PWD:/usr/src/rusthound-ce rusthound-ce linux

Installation

Crates.io Version Crates.io Total Downloads

# Install and/or update RustHound-CE from cargo command
cargo install rusthound-ce

Usage

Here's an example of a command to collect domain objects and obtain the zip archive containing the json files to be imported into BloodHound CE:

rusthound-ce -d DOMAIN.LOCAL -u USERNAME@DOMAIN.LOCAL -z

More information and examples with how to compile RustHound-CE or how to use RustHound-CE can be found directly on the help page.

Special thanks to

Dependencies

~29–68MB
~1M SLoC