Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/RustCrypto/block-ciphers
Collection of block cipher algorithms written in pure Rust
https://github.com/RustCrypto/block-ciphers
Last synced: 4 months ago
JSON representation
Collection of block cipher algorithms written in pure Rust
- Host: GitHub
- URL: https://github.com/RustCrypto/block-ciphers
- Owner: RustCrypto
- Created: 2016-12-16T11:35:26.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-10-24T01:59:48.000Z (4 months ago)
- Last Synced: 2024-10-24T17:53:37.797Z (4 months ago)
- Language: Rust
- Homepage:
- Size: 2.45 MB
- Stars: 671
- Watchers: 14
- Forks: 131
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-cryptography-rust - block-ciphers
README
# RustCrypto: block ciphers
[![Project Chat][chat-image]][chat-link]
[![dependency status][deps-image]][deps-link]
![Apache2/MIT licensed][license-image]
[![HAZMAT][hazmat-image]][hazmat-link]Collection of [block ciphers] written in pure Rust.
## Higher level constructions
Crates in this repository implement ONLY raw block cipher functionality defined by traits in the [`cipher`] crate.
In practice block ciphers are rarely used in isolation.
Instead, they usually play role of a building block for higher level constructions.
In RustCrypto such constructions are implemented generically over block ciphers in separate repositories:
- [AEADs](https://github.com/RustCrypto/AEADs): GCM, SIV, CCM, MGM, etc.
- [MACs](https://github.com/RustCrypto/MACs): CMAC, PMAC.
- [Block modes](https://github.com/RustCrypto/block-modes): CTR, CBC, CFB, etc.
- [Key wrapping](https://github.com/RustCrypto/key-wraps): AES-KW.Most users should use constructions defined in these repositories without directly relying on raw block cipher functionality.
[`cipher`]: https://docs.rs/cipher
## Warnings
Currently only the `aes` crate provides constant-time implementation and has received a third-party security audit.
Other crates in this repository are not implemented in a constant-time manner and have not yet received any formal cryptographic and security reviews.
It's generally recommended not to use other cipher implementations in this repository besides the `aes` crate.
**USE AT YOUR OWN RISK.**
## Supported algorithms
| Name | Crate name | crates.io | Docs | MSRV |
|------|------------|-----------|------|------|
| [AES] (Rijndael) | [`aes`] | [data:image/s3,"s3://crabby-images/b92e2/b92e2c3fefb05f3607abdd6651f2dcd5922cc0c3" alt="crates.io"](https://crates.io/crates/aes) | [data:image/s3,"s3://crabby-images/3250a/3250a59ddb8ec8c4550935372fdb87054c500ee2" alt="Documentation"](https://docs.rs/aes) | ![MSRV 1.65][msrv-1.65] |
| [ARIA] | [`aria`] | [data:image/s3,"s3://crabby-images/48893/48893e2196c304e2a1cd26ea01bcb81d20e9bf9e" alt="crates.io"](https://crates.io/crates/aria) | [data:image/s3,"s3://crabby-images/aa6ce/aa6ce26ba15824cc383eb407fe9ad31ab2b6260f" alt="Documentation"](https://docs.rs/aria) | ![MSRV 1.65][msrv-1.65] |
| [BelT] block cipher | [`belt-block`] | [data:image/s3,"s3://crabby-images/6d9cd/6d9cd8387113250f816daef725f7f4466c1a882a" alt="crates.io"](https://crates.io/crates/belt-block) | [data:image/s3,"s3://crabby-images/7f16a/7f16ac48923fd86978126c9c23711d4a581a7108" alt="Documentation"](https://docs.rs/belt-block) | ![MSRV 1.65][msrv-1.65] |
| [Blowfish] | [`blowfish`] | [data:image/s3,"s3://crabby-images/5fbee/5fbeed0c36748a2ba86d60e40821a92af36fadc2" alt="crates.io"](https://crates.io/crates/blowfish) | [data:image/s3,"s3://crabby-images/899a7/899a7d8a6e5104464b9bdfe29b816a78f940c240" alt="Documentation"](https://docs.rs/blowfish) | ![MSRV 1.65][msrv-1.65] |
| [Camellia] | [`camellia`] | [data:image/s3,"s3://crabby-images/e32b4/e32b4128facf1bd475e113ad4dd6c665e69fb193" alt="crates.io"](https://crates.io/crates/camellia) | [data:image/s3,"s3://crabby-images/2935a/2935a9532961f344f6f9979cd5320a8f7cd9532c" alt="Documentation"](https://docs.rs/camellia) | ![MSRV 1.65][msrv-1.65] |
| [CAST5] (CAST-128) | [`cast5`] | [data:image/s3,"s3://crabby-images/d25e1/d25e1de07bbc9b0e87bd536349a2b62017c05bf0" alt="crates.io"](https://crates.io/crates/cast5) | [data:image/s3,"s3://crabby-images/50f4e/50f4e63ff61e44dd76d135b3dee94772141ecc69" alt="Documentation"](https://docs.rs/cast5) | ![MSRV 1.65][msrv-1.65] |
| [CAST6] (CAST-256) | [`cast6`] | [data:image/s3,"s3://crabby-images/59bae/59bae948fffe253b7a2a6572d80727f16454ba4d" alt="crates.io"](https://crates.io/crates/cast6) | [data:image/s3,"s3://crabby-images/c30b5/c30b58c407c505f99021a35cb04b169a171d2908" alt="Documentation"](https://docs.rs/cast6) | ![MSRV 1.65][msrv-1.65] |
| [DES] + [3DES] (DEA, 3DEA) | [`des`] | [data:image/s3,"s3://crabby-images/0b509/0b5099c151710da139ad2b4d130672d168e4f1c6" alt="crates.io"](https://crates.io/crates/des) | [data:image/s3,"s3://crabby-images/0adb0/0adb0c0abbe7b8433da1b0066cf6ce55f27ac5e0" alt="Documentation"](https://docs.rs/des) | ![MSRV 1.65][msrv-1.65] |
| [IDEA] | [`idea`] | [data:image/s3,"s3://crabby-images/c2468/c246831889ad738280df160ef77921be28b551cc" alt="crates.io"](https://crates.io/crates/idea) | [data:image/s3,"s3://crabby-images/60030/60030bcf70e1dc7bf17de082c143de6279469d06" alt="Documentation"](https://docs.rs/idea) | ![MSRV 1.65][msrv-1.65] |
| [Kuznyechik] (GOST R 34.12-2015) | [`kuznyechik`] | [data:image/s3,"s3://crabby-images/ba75f/ba75f2290b087a0fde8e596a519c4ef2b265660c" alt="crates.io"](https://crates.io/crates/kuznyechik) | [data:image/s3,"s3://crabby-images/23727/23727c9be2766ab881e3060f252de408b7002092" alt="Documentation"](https://docs.rs/kuznyechik) | ![MSRV 1.65][msrv-1.65] |
| [Magma] (GOST R 34.12-2015) | [`magma`] | [data:image/s3,"s3://crabby-images/bb4ad/bb4ad86e90409e2867c056064129ab3c3c8670e2" alt="crates.io"](https://crates.io/crates/magma) | [data:image/s3,"s3://crabby-images/7ed00/7ed0053d1a92aaf097106882d79ad3968b828b77" alt="Documentation"](https://docs.rs/magma) | ![MSRV 1.65][msrv-1.65] |
| [RC2] (ARC2) | [`rc2`] | [data:image/s3,"s3://crabby-images/15698/15698badb94a6731f8fdf5e812ab936f8ad10dca" alt="crates.io"](https://crates.io/crates/rc2) | [data:image/s3,"s3://crabby-images/2d5fb/2d5fb7125423422e45c980a4bad2d1bf7e7eba87" alt="Documentation"](https://docs.rs/rc2) | ![MSRV 1.65][msrv-1.65] |
| [RC5] | [`rc5`] | [data:image/s3,"s3://crabby-images/ef056/ef056dfa9bcfd6c295e9140a0c9ee4c50f3595ec" alt="crates.io"](https://crates.io/crates/rc5) | [data:image/s3,"s3://crabby-images/6c28a/6c28a076e2399a7991ae36f3df4ba1dd91be3550" alt="Documentation"](https://docs.rs/rc5) | ![MSRV 1.65][msrv-1.65] |
| [Serpent] | [`serpent`] | [data:image/s3,"s3://crabby-images/d9e22/d9e228d3164dbe6945d0638100e1a86d0718408a" alt="crates.io"](https://crates.io/crates/serpent) | [data:image/s3,"s3://crabby-images/e224f/e224febb0a1dfda8588dbad10bd5c7484ef7d03b" alt="Documentation"](https://docs.rs/serpent) | ![MSRV 1.65][msrv-1.65] |
| [SM4] | [`sm4`] | [data:image/s3,"s3://crabby-images/19745/19745032beace0a01f8f713d6055c0f3e2dc153e" alt="crates.io"](https://crates.io/crates/sm4) | [data:image/s3,"s3://crabby-images/5573f/5573fbd2085415ce5ab3ba00be416973faca48d6" alt="Documentation"](https://docs.rs/sm4) | ![MSRV 1.65][msrv-1.65] |
| [Speck] | [`speck-cipher`] | [data:image/s3,"s3://crabby-images/63ba2/63ba26ff7cc80df1ef989e14eda187be375e371c" alt="crates.io"](https://crates.io/crates/speck-cipher) | [data:image/s3,"s3://crabby-images/2e465/2e465df2cd125f7d4d0de5b1049f51b63b4963bd" alt="Documentation"](https://docs.rs/speck-cipher) | ![MSRV 1.65][msrv-1.65] |
| [Threefish] | [`threefish`] | [data:image/s3,"s3://crabby-images/0beeb/0beeb091edad50c62493284f3a28f7e28ed4c386" alt="crates.io"](https://crates.io/crates/threefish) | [data:image/s3,"s3://crabby-images/af7ed/af7ed0e20f0ec8e23437f121d85c07f28b0bb74d" alt="Documentation"](https://docs.rs/threefish) | ![MSRV 1.65][msrv-1.65] |
| [Twofish] | [`twofish`] | [data:image/s3,"s3://crabby-images/ddd48/ddd48fea2288f1d9db8bfab5f11efa82699e8c76" alt="crates.io"](https://crates.io/crates/twofish) | [data:image/s3,"s3://crabby-images/725e0/725e005d582fe53d0c1d3d1edba611377fbc0704" alt="Documentation"](https://docs.rs/twofish) | ![MSRV 1.65][msrv-1.65] |
| [XTEA] | [`xtea`] | [data:image/s3,"s3://crabby-images/0442c/0442c278543708ca1e6069b67a938497c5b1d70e" alt="crates.io"](https://crates.io/crates/xtea) | [data:image/s3,"s3://crabby-images/e9368/e93680d6e920ea0af29d46814b1a0f15ce9e0993" alt="Documentation"](https://docs.rs/xtea) | ![MSRV 1.65][msrv-1.65] |### Minimum Supported Rust Version (MSRV) Policy
MSRV bump is considered a breaking change and will be performed only with a minor version bump.
## License
All crates licensed under either of
* [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0)
* [MIT license](http://opensource.org/licenses/MIT)at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.[//]: # (badges)
[chat-image]: https://img.shields.io/badge/zulip-join_chat-blue.svg
[chat-link]: https://rustcrypto.zulipchat.com/#narrow/stream/260039-block-ciphers
[deps-image]: https://deps.rs/repo/github/RustCrypto/block-ciphers/status.svg
[deps-link]: https://deps.rs/repo/github/RustCrypto/block-ciphers
[license-image]: https://img.shields.io/badge/license-Apache2.0/MIT-blue.svg
[hazmat-image]: https://img.shields.io/badge/crypto-hazmat%E2%9A%A0-red.svg
[hazmat-link]: https://github.com/RustCrypto/meta/blob/master/HAZMAT.md
[msrv-1.65]: https://img.shields.io/badge/rustc-1.65.0+-blue.svg[//]: # (crates)
[`aes`]: ./aes
[`aria`]: ./aria
[`belt-block`]: ./belt-block
[`blowfish`]: ./blowfish
[`camellia`]: ./camellia
[`cast5`]: ./cast5
[`cast6`]: ./cast6
[`des`]: ./des
[`idea`]: ./idea
[`kuznyechik`]: ./kuznyechik
[`magma`]: ./magma
[`rc2`]: ./rc2
[`rc5`]: ./rc5
[`serpent`]: ./serpent
[`sm4`]: ./sm4
[`speck-cipher`]: ./speck
[`threefish`]: ./threefish
[`twofish`]: ./twofish
[`xtea`]: ./xtea[//]: # (links)
[block ciphers]: https://en.wikipedia.org/wiki/Block_cipher
[//]: # (algorithms)
[AES]: https://en.wikipedia.org/wiki/Advanced_Encryption_Standard
[ARIA]: https://en.wikipedia.org/wiki/ARIA_(cipher)
[BelT]: https://ru.wikipedia.org/wiki/BelT
[Blowfish]: https://en.wikipedia.org/wiki/Blowfish_(cipher)
[Camellia]: https://en.wikipedia.org/wiki/Camellia_(cipher)
[CAST5]: https://en.wikipedia.org/wiki/CAST-128
[CAST6]: https://en.wikipedia.org/wiki/CAST-256
[DES]: https://en.wikipedia.org/wiki/Data_Encryption_Standard
[3DES]: https://en.wikipedia.org/wiki/Triple_DES
[IDEA]: https://simple.wikipedia.org/wiki/International_Data_Encryption_Algorithm
[Kuznyechik]: https://en.wikipedia.org/wiki/Kuznyechik
[Magma]: https://en.wikipedia.org/wiki/GOST_(block_cipher)
[RC2]: https://en.wikipedia.org/wiki/RC2
[RC5]: https://en.wikipedia.org/wiki/RC5
[Serpent]: https://en.wikipedia.org/wiki/Serpent_(cipher)
[SM4]: https://en.wikipedia.org/wiki/SM4_(cipher)
[Speck]: https://en.wikipedia.org/wiki/Speck_(cipher)
[Threefish]: https://en.wikipedia.org/wiki/Threefish
[Twofish]: https://en.wikipedia.org/wiki/Twofish
[XTEA]: https://en.wikipedia.org/wiki/XTEA