#post-quantum-cryptography #post-quantum #kyber #kem #shared-secret

kyber-rust

A Rust wrapper for the Kyber post-quantum key encapsulation mechanism

1 unstable release

0.2.1 Sep 24, 2024
0.2.0 Sep 24, 2024
0.1.0 Sep 20, 2024

#2069 in Cryptography

MIT license

115KB
160 lines

Contains (Windows DLL, 100KB) kyber.dll

Kyber-Rust

A Rust wrapper for the Kyber post-quantum key encapsulation mechanism.

Overview

This crate provides a safe Rust interface to the Kyber algorithm, which is a finalist in the NIST Post-Quantum Cryptography standardization process. Kyber is a key encapsulation mechanism (KEM) that is believed to be secure against attacks by quantum computers.

Features

  • Generate Kyber keypairs
  • Encapsulate shared secrets
  • Decapsulate shared secrets
  • Easy-to-use high-level API

Installation

Add this to your Cargo.toml:

[dependencies]
kyber-rust = "0.2.1"

Usage

Here's a basic example of how to use the Kyber-Rust library:

use kyber_rust::{generate_keypair, encapsulate, decapsulate};

fn main() -> Result<(), String> {
    // Generate a keypair
    let (public_key, secret_key) = generate_keypair()?;

    // Encapsulate a shared secret
    let (ciphertext, shared_secret_enc) = encapsulate(&public_key)?;

    // Decapsulate the shared secret
    let shared_secret_dec = decapsulate(&ciphertext, &secret_key)?;

    // Verify that the shared secrets match
    assert_eq!(shared_secret_enc, shared_secret_dec);

    Ok(())
}

Safety

This crate uses unsafe Rust to interface with the C implementation of Kyber. While efforts have been made to ensure safety, users should be aware of the potential risks associated with FFI and unsafe code.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contribution

Contributions are welcome! Please feel free to submit a Pull Request.

Disclaimer

This implementation is for educational and research purposes only. It has not been audited for production use.

Dependencies

~0–4.5MB