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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
use std::fmt::{self, Debug};
use super::{Command, Response};
use {CommandType, Connector, ObjectId, Session, SessionError};
pub const ED25519_SIGNATURE_SIZE: usize = 64;
pub fn sign_ed25519<C, T>(
session: &mut Session<C>,
key_id: ObjectId,
data: T,
) -> Result<Ed25519Signature, SessionError>
where
C: Connector,
T: Into<Vec<u8>>,
{
session.send_encrypted_command(SignDataEdDSACommand {
key_id,
data: data.into(),
})
}
#[derive(Serialize, Deserialize, Debug)]
pub(crate) struct SignDataEdDSACommand {
pub key_id: ObjectId,
pub data: Vec<u8>,
}
impl Command for SignDataEdDSACommand {
type ResponseType = Ed25519Signature;
}
pub struct Ed25519Signature(pub [u8; ED25519_SIGNATURE_SIZE]);
impl Response for Ed25519Signature {
const COMMAND_TYPE: CommandType = CommandType::SignDataEdDSA;
}
impl AsRef<[u8]> for Ed25519Signature {
fn as_ref(&self) -> &[u8] {
&self.0[..]
}
}
impl Debug for Ed25519Signature {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "Ed25519Signature(")?;
for (i, byte) in self.0.iter().enumerate() {
write!(f, "{:02x}", byte)?;
write!(
f,
"{}",
if i == ED25519_SIGNATURE_SIZE - 1 {
")"
} else {
":"
}
)?;
}
Ok(())
}
}
impl_array_serializers!(Ed25519Signature, ED25519_SIGNATURE_SIZE);