#cipher #block-cipher #key-exchange #encryption-key #prime-field

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

#300 in Cryptography

Download history 428/week @ 2023-12-22 151/week @ 2023-12-29 204/week @ 2024-01-05 208/week @ 2024-01-12 192/week @ 2024-01-19 165/week @ 2024-01-26 99/week @ 2024-02-02 38/week @ 2024-02-09 101/week @ 2024-02-16 156/week @ 2024-02-23 151/week @ 2024-03-01 148/week @ 2024-03-08 124/week @ 2024-03-15 139/week @ 2024-03-22 180/week @ 2024-03-29 109/week @ 2024-04-05

569 downloads per month
Used in 24 crates (14 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