use super::cas_hmac::CASHMAC;
use hmac::{Hmac, Mac};
use sha2::Sha256;
type HmacSha256 = Hmac<Sha256>;
pub struct HMAC;
impl CASHMAC for HMAC {
fn sign(key: Vec<u8>, message: Vec<u8>) -> Vec<u8> {
let mut mac = HmacSha256::new_from_slice(&key).unwrap();
mac.update(&message);
let result = mac.finalize().into_bytes().to_vec();
result
}
fn verify(key: Vec<u8>, message: Vec<u8>, signature: Vec<u8>) -> bool {
let mut mac = HmacSha256::new_from_slice(&key).unwrap();
mac.update(&message);
return mac.verify_slice(&signature).is_ok();
}
}