#encryption

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

#1054 in Cryptography

Download history 608/week @ 2025-12-19 512/week @ 2025-12-26 528/week @ 2026-01-02 622/week @ 2026-01-09 276/week @ 2026-01-16 482/week @ 2026-01-23 590/week @ 2026-01-30 338/week @ 2026-02-06 315/week @ 2026-02-13 310/week @ 2026-02-20 432/week @ 2026-02-27 280/week @ 2026-03-06 379/week @ 2026-03-13 271/week @ 2026-03-20 314/week @ 2026-03-27 312/week @ 2026-04-03

1,361 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
~29K SLoC