nobsign

Crates.ionobsign
lib.rsnobsign
version0.2.0
sourcesrc
created_at2016-08-16 10:38:10.382281
updated_at2019-01-16 15:06:00.37216
descriptionA simple but effective sign library, written in Rust
homepagehttps://github.com/badboy/nobsign
repositoryhttps://github.com/badboy/nobsign
max_upload_size
id5986
size11,917
Engine Devs (github:amethyst:engine-devs)

documentation

http://badboy.github.io/nobsign/

README

nobsign

crates.io Build Status

A simple but effective sign library, written in Rust.

Ported from nobi, which itself is a port of itsdangerous.

Documentation

Online Documentation.

Possible use cases

  • Creating an activation link for users
  • Creating a password reset link

Basic Example:

use nobsign::Signer;
let signer = Signer::new(b"my secret");

// Let's say the user's ID is 101
let signed = signer.sign("101");

// You can now email this url to your users!
let url = format!("http://yoursite.com/activate/?key={}", signed);

// Later check the signature and get the value back
let unsigned = signer.unsign(&signed).unwrap();

Example with timestamped signatures

use nobsign::TimestampSigner;
let signer = TimestampSigner::new(b"my secret");

// Let's say the user's ID is 101
let signed = signer.sign("101");

// You can now email this url to your users!
let url = format!("http://yoursite.com/activate/?key={}", signed);

// In your code, you can verify the expiration:
signer.unsign(&signed, 86400).unwrap(); // 1 day expiration
Commit count: 43

cargo fmt