1 stable release

1.0.0 Sep 28, 2024

#743 in Cryptography

MIT license

12KB
101 lines

Signatory

Signatory is a lightweight Rust library for generating and validating signatures, encoding/decoding to and from Base64, and handling timestamp insertion for secure data transmission. It leverages MD5 hashing and allows for URL parameter construction with signed values.

Features

  • Generate signatures by hashing URL-like query strings.
  • Base64 encode and decode JSON objects.
  • Automatically adds a timestamp if none is provided.
  • Validates signatures for incoming requests.

Installation

Add Signatory to your Cargo.toml dependencies:

[dependencies]
signatory = { git = "https://github.com/cakioe/signatory.git" }

Usage

use signatory::Signatory;
use serde_json::Value;
use std::collections::HashMap;

fn main() {
let key = "your_secret_key".to_string();
let signatory = Signatory::new(key);

    let mut params = HashMap::new();
    params.insert("client_id".to_string(), Value::String("16327128".to_string()));
    params.insert("method".to_string(), Value::String("android.shutdown".to_string()));
    params.insert("timestamp".to_string(), Value::String("1727494645".to_string()));

    // Generate a signature
    let sign = signatory.gen_signature(params.clone()).unwrap();
    println!("Generated signature: {}", sign);

    // Add signature to the params and encode to Base64
    let base64_str = signatory.to_base64_str(params.clone()).unwrap();
    println!("Base64 Encoded: {}", base64_str);

    // Decode the Base64 string back to HashMap
    let decoded_params = signatory.decrypt_base64_str(base64_str).unwrap();
    println!("Decoded params: {:?}", decoded_params);

    // Validate the signature
    let is_valid = signatory.check_signature(decoded_params.clone(), sign.clone());
    assert!(is_valid, "Signature is valid");
}

Dependencies

~1.8–3MB
~56K SLoC