#block-cipher #cipher #block-size #key-exchange #key-length

libsm

A Rust Library of China's Standards of Encryption Algorithms (SM2/3/4)

5 unstable releases

0.6.0 Dec 26, 2023
0.5.1 Apr 19, 2023
0.5.0 May 26, 2022
0.4.1 Aug 20, 2021
0.3.0 Jul 10, 2018

#1225 in Cryptography

Download history 64/week @ 2024-10-19 54/week @ 2024-10-26 75/week @ 2024-11-02 43/week @ 2024-11-09 50/week @ 2024-11-16 76/week @ 2024-11-23 83/week @ 2024-11-30 192/week @ 2024-12-07 128/week @ 2024-12-14 15/week @ 2024-12-21 12/week @ 2024-12-28 60/week @ 2025-01-04 72/week @ 2025-01-11 51/week @ 2025-01-18 30/week @ 2025-01-25 185/week @ 2025-02-01

362 downloads per month
Used in 24 crates (15 directly)

Apache-2.0

120KB
3K SLoC

Libsm

Libsm is an open source pure rust library of China Cryptographic Algorithm Standards. It is completed by a collaborative effort between the Cryptape Technology LLC. and BEIHANG KNOC LAB. And now this project is maintained by Cryptape Technology LLC.

GM/T Algorithms

Libsm implements the following GM/T cryptographic algorithms:

  • SM2 (GM/T 0003-2012): elliptic curve cryptographic schemes including digital signature scheme, public key encryption, (authenticated) key exchange protocol and one recommended 256-bit prime field curve sm2p256v1.
  • SM3 (GM/T 0004-2012): cryptographic hash function with 256-bit digest length.
  • SM4 (GM/T 0002-2012): block cipher with 128-bit key length and 128-bit block size, also named SMS4.

Documents

License

Libsm is currently under the Apache 2.0 license.

Dependencies

~1–1.6MB
~31K SLoC