tlock_age

Crates.iotlock_age
lib.rstlock_age
version0.0.5
sourcesrc
created_at2023-03-22 20:48:10.522683
updated_at2024-02-29 09:41:44.698223
descriptionRust encryption library for hybrid time-lock encryption.
homepagehttps://github.com/thibmeu/tlock-rs
repositoryhttps://github.com/thibmeu/tlock-rs
max_upload_size
id817469
size101,244
Thibault (thibmeu)

documentation

README

tlock_age: Hybrid Timelock Encryption/Decryption in Rust

Documentation License crates.io

tlock_age is a library to encrypt and decrypt age filekey using tlock scheme. It provides an age Identity and Recipient consuming Threshold BLS signatures provided by drand beacons.

The reference interroperable Go implementation is available at drand/tlock.

Tables of Content

Features

  • Timelock encryption and decryption in the age format
  • ASCII Armor
  • tlock header decryption
  • Encryption with public key on G1 and G2
  • Interroperability with Go and JS implementation
  • wasm32 compatible library

Installation

Environment CLI Command
Cargo (Rust 1.74+) cargo install tlock_age

The library is tested against the following targets: x86_64-unknown-linux-gnu, armv7-unknown-linux-gnueabihf, aarch64-unknown-linux-gnu, wasm32-wasi.

Usage

Code examples are provided in tlock_age/examples.

The tlock system relies on unchained drand networks.

This crate does not provide a drand client. You can use drand_core.

Security Considerations

This software has not been audited. Please use at your sole discretion. With this in mind, dee security relies on the following:

FAQ

How does practical timelock encryption work

For the simple explanation, you can use Handwaving Cryptography.

For a more detailed one, you should take time to read tlock: Practical Timelock Encryption from Threshold BLS by Nicolas Gailly, Kelsey Melissaris, and Yolan Romailler.

How can I use it from the command line

You need a client. Clients using tlock-rs are

License

This project is under the MIT license.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be MIT licensed as above, without any additional terms or conditions.

Commit count: 57

cargo fmt