Skip to content

ideal-lab5/timelock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

52 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Timelock Encryption

Timelock is an implemention of timelock encryption using the Boneh Franklin -Idenity Based Encryption scheme. Designed for versatility, it provides support for both Rust and JavaScript. In addition, it is capable of supporting multiple types of randomness beacons, including the Ideal Network and drand.

Getting Started

Timelock is organized into core components and language-specific bindings to support WASM:

  • Core Library: The timelock crate implements the core encryption algorithms and provides support for native Rust applications.
  • WASM bindings: The wasm lib provides wasm bindings for the timelock encryption implementation, enabling usage of timelock encryption in JavaScript-based applications in a web-enabled context.
  • TypeScript Bindings: The ts library is a TypeScript wrapper to adapt the wasm for easy integration in JavaScript projects.
  • Python Bindings: The py library provides Python bindings for timelock encryption.

For Rust Developers

Navigate to the core timelock implementation readme for details on building and using it in Rust.

timelock = { git = "https://github.com/ideal-lab5/timelock.git", default-features = false }

For Javascript Developers

Navigate to the typescript bindings readme for more information on integration of @ideallabs/timelock.js in javascript apps.

npm i @ideallabs/timelock.js

For Python Developers

The python bindings are enabled with PyO3 and allow timelock encryption and decryption to be computed in Python.

pip install timelock

Contributing and Code of Conduct

Contributions are welcome! Feel free to open issues for problems or feature requests while we work on setting up our contributors guidelines.

License

Apache-2.0