feat: v1.1.11, piv sign works, add piv generate
This commit is contained in:
@@ -84,7 +84,7 @@ impl Command for CommandImpl {
|
||||
|
||||
if let Some(sha256) = sha256 {
|
||||
let sha256_hex = opt_result!(hex::decode(sha256.trim()), "Decode sha256 failed: {}");
|
||||
let sha256_hex = copy_sha256(&sha256_hex)?;
|
||||
let sha256_hex = crate::digest::copy_sha256(&sha256_hex)?;
|
||||
opt_result!(trans.verify_pw1_sign(pin.as_ref()), "User sign pin verify failed: {}");
|
||||
success!("User sign pin verify success!");
|
||||
let sig = trans.signature_for_hash(Hash::SHA256(sha256_hex))?;
|
||||
@@ -99,7 +99,7 @@ impl Command for CommandImpl {
|
||||
}
|
||||
if let Some(sha384) = sha384 {
|
||||
let sha384_hex = opt_result!(hex::decode(sha384.trim()), "Decode sha384 failed: {}");
|
||||
let sha384_hex = copy_sha384(&sha384_hex)?;
|
||||
let sha384_hex = crate::digest::copy_sha384(&sha384_hex)?;
|
||||
opt_result!(trans.verify_pw1_sign(pin.as_ref()), "User sign pin verify failed: {}");
|
||||
success!("User sign pin verify success!");
|
||||
let sig = trans.signature_for_hash(Hash::SHA384(sha384_hex))?;
|
||||
@@ -114,7 +114,7 @@ impl Command for CommandImpl {
|
||||
}
|
||||
if let Some(sha512) = sha512 {
|
||||
let sha512_hex = opt_result!(hex::decode(sha512.trim()), "Decode sha512 failed: {}");
|
||||
let sha512_hex = copy_sha512(&sha512_hex)?;
|
||||
let sha512_hex = crate::digest::copy_sha512(&sha512_hex)?;
|
||||
opt_result!(trans.verify_pw1_sign(pin.as_ref()), "User sign pin verify failed: {}");
|
||||
success!("User sign pin verify success!");
|
||||
let sig = trans.signature_for_hash(Hash::SHA512(sha512_hex))?;
|
||||
@@ -152,22 +152,3 @@ fn calc_file_digest<D>(file_name: &str) -> XResult<Vec<u8>> where D: Digest {
|
||||
hasher.update(&buf[..len]);
|
||||
}
|
||||
}
|
||||
|
||||
macro_rules! define_copy_array {
|
||||
($fn_name: ident, $len: tt) => (
|
||||
fn $fn_name(in_arr: &[u8]) -> XResult<[u8; $len]> {
|
||||
if in_arr.len() != $len {
|
||||
return simple_error!("Array length is not: {}, but is: {}", $len, in_arr.len());
|
||||
}
|
||||
let mut out_arr = [0_u8; $len];
|
||||
for i in 0..$len {
|
||||
out_arr[i] = in_arr[i];
|
||||
}
|
||||
Ok(out_arr)
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
define_copy_array!(copy_sha256, 0x20);
|
||||
define_copy_array!(copy_sha384, 0x30);
|
||||
define_copy_array!(copy_sha512, 0x40);
|
||||
|
||||
Reference in New Issue
Block a user