A C++ library and CLI tool 🔧 to seal a directory’s state 📦 📨. In essence, gets the hash of a directory.
Currently barely stable, and far from how I'd imagined it.
While that technically doesn’t mean one specific thing (capable of being interpreted and/or implemented in different ways), here it means recursively hashing its contents using a tree structure. Including the metadata of each dir-tree node as well, this “stamp” hash that is thus calculated should make it very hard for a directory to be tampered with secretly.
It’s been done before — hash-trees (also “Merkle trees” after their creator Ralph C. Merkle) of directories are used in the BitTorrent protocol 📥, macOS SSV, and git 🎋⌥ itself.
But this project aims at making a near-standalone library (as well as an exemplifying frontend CLT) available, for any other great ideas yet unimplemented to gain a head-start.
documentation coming soon
(once the library gets big enough — if it gets big enough)
Relies on the GnuPG project’s crypto library (libgcrypt
) for all the hashing work.
- Ensure that
libgcrypt
(≥v1.8.7
) is installed on your system. If you’re on linux, you can probably skip this step. For other platforms, the easiest way is often to get GnuPG itself. There are several binaries suggested by GnuPG here. - Ensure your compiler and linker have access to
libgcrypt
’s headers and object-libraries. You can find out what flags to pass to your compiler by runninglibgcrypt-config --cflags --libs
, once you have ensured thatlibgcrypt
is installed. - Build!
- macOS (requires Xcode CLT or a separate installation of
clang
orgcc
):clang++ -dylib -std=gnu++17 ./src/* -o libsealdir.dylib
- Linux:
g++ -flinker-output=dyn -std=gnu++17 ./src/* -o libsealdir.so
- macOS (requires Xcode CLT or a separate installation of
N.B.: libgcrypt
is distributed under the GNU GPL v3, which has different terms and distribution-restrictions from the BSD “3-Clause” license used in the rest of this software.