22 releases

new 0.11.2 Jan 6, 2025
0.11.0 Oct 4, 2024
0.10.0 Jul 18, 2024
0.9.3 Mar 25, 2024
0.3.0 Mar 27, 2020

#92 in Unix APIs

Download history 1006/week @ 2024-09-20 798/week @ 2024-09-27 1003/week @ 2024-10-04 2343/week @ 2024-10-11 527/week @ 2024-10-18 2845/week @ 2024-10-25 1726/week @ 2024-11-01 1531/week @ 2024-11-08 1403/week @ 2024-11-15 1422/week @ 2024-11-22 1054/week @ 2024-11-29 1125/week @ 2024-12-06 1275/week @ 2024-12-13 862/week @ 2024-12-20 352/week @ 2024-12-27 2474/week @ 2025-01-03

5,112 downloads per month
Used in 3 crates

MPL-2.0 license

190KB
4K SLoC

Latest Version Documentation

libcryptsetup-rs

This crate provides Rust bindings for libcryptsetup.

Note on thread-safety

libcryptsetup is not thread-safe and also depends on libraries that are not thread-safe. Any use of libcryptsetup by default in a multithreaded environment will result in undefined behavior.

As a workaround, this library provides a feature (mutex) to cause all calls to libcryptsetup to acquire a crate-level mutex. This will enforce single threaded access to all invocations of the libcryptsetup API.

Rust's decision to make pointers !Send should be respected. Any data structure that contains a pointer is not safe to send across threads. Providing an unsafe impl Send {} for any data structure provided by libcryptsetup-rs that is not Send may result in undefined behavior.

Building

The libcryptsetup bindings require some dependencies outside of cargo to build properly:

  1. cryptsetup (provided by cryptsetup on Fedora)
  2. cryptsetup development headers (provided by cryptsetup-devel on Fedora)
  3. libclang (provided by clang on Fedora)

Sanity testing bindings

There is one test that actually invokes libcryptsetup and can be used for basic sanity testing of the bindings as it will only succeed if low level bindings are correctly generated, the high level bindings build, and libcryptsetup successfully encrypts a loopback device.

This can be invoked as follows:

make test-loopback

Dependencies

~1–4.5MB
~85K SLoC