1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
use crate::rng::{ SecKeyGen, PubKeyGen };
use std::error::Error;
#[derive(Debug, Eq, PartialEq, Copy, Clone)]
pub struct SignerInfo {
pub name: &'static str,
pub sig_len: usize,
pub sec_key_len: usize,
pub pub_key_len: usize
}
pub trait Signer: SecKeyGen + PubKeyGen {
fn info(&self) -> SignerInfo;
fn sign(&self, buf: &mut[u8], data: &[u8], sec_key: &[u8])
-> Result<usize, Box<dyn Error + 'static>>;
fn verify(&self, data: &[u8], sig: &[u8], pub_key: &[u8])
-> Result<(), Box<dyn Error + 'static>>;
}