Cryptography Utils for Rust
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
renovate[bot] 6a27732f4d fix(deps): update rust crate serde to 1.0.138 4 days ago
.github/workflows ci: update 3 weeks ago
examples chore(examples): add hmac in sha example 7 days ago
src chore(release): v0.4.0 7 days ago
.gitignore chore: add examples 3 weeks ago
CHANGELOG.md chore(changelog): fix links 7 days ago
Cargo.lock fix(deps): update rust crate serde to 1.0.138 4 days ago
Cargo.toml fix(deps): update rust crate serde to 1.0.138 4 days ago
LICENSE initial commit 4 weeks ago
README.md chore(release): v0.4.0 7 days ago
renovate.json chore: setup renovatebot 3 weeks ago

README.md

crypto-utils

github crates-io docs-rs ci

Cryptography Utils for Rust

Importing

The driver is available on crates-io. To use the driver in your application, simply add it to your project's Cargo.toml.

[dependencies]
crypto-utils = "0.4.0"

How to use?

Compute a Sha hash

Add sha features (is enabled by default)

[dependencies]
crypto-utils = { version = "...", features = ["sha"] }

Quick and easy Sha1, Sha256 and Sha512 hash computing.

use crypto_utils::sha::{Algorithm, CryptographicHash};

// input data for a hasher
let input = "P@ssw0rd"; // &str

// compute hash
let hash_bytes = CryptographicHash::hash(Algorithm::SHA1, input.as_bytes()); // Vec<u8>

// decode hash to a String
let hash = hex::encode(hash_bytes); // String

assert_eq!(hash, "21bd12dc183f740ee76f27b78eb39c8ad972a757".to_string())

Json Web Token

Add jwt features (is enabled by default)

[dependencies]
crypto-utils = { version = "...", features = ["jwt"] }

Create and decode a token

use crypto_utils::jsonwebtoken::{Claims, Token};

let secret = b"secret";
let user_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx";

// create claims
let claims = Claims::new(user_id, 24);

// create token
let token = Token::new(secret, claims).unwrap();

// decode token
let decoded = Token::decode(secret, token.encoded).unwrap();

All Feature flags

Feature Description Dependencies Default
sha Enable support for the Sha1, Sha256 and Sha512 hasher sha and sha2 yes
jwt Enable support for the Json Web Token utils chrono, serde and jsonwebtoken yes

License: MIT