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
use super::put_object::PutObjectParams;
use super::{Command, Response};
use session::SessionErrorKind::ProtocolError;
use {
Adapter, Capability, CommandType, Domain, ObjectId, ObjectLabel, OtpAlg, Session, SessionError,
};
pub fn put_otp_aead_key<A: Adapter, T: Into<Vec<u8>>>(
session: &mut Session<A>,
key_id: ObjectId,
label: ObjectLabel,
domains: Domain,
capabilities: Capability,
algorithm: OtpAlg,
key_bytes: T,
) -> Result<ObjectId, SessionError> {
let data = key_bytes.into();
if data.len() != algorithm.key_len() {
fail!(
ProtocolError,
"invalid key length for {:?}: {} (expected {})",
algorithm,
data.len(),
algorithm.key_len()
);
}
session
.send_command(PutOTPAEADKeyCommand {
params: PutObjectParams {
id: key_id,
label,
domains,
capabilities,
algorithm: algorithm.into(),
},
data,
}).map(|response| response.key_id)
}
#[derive(Serialize, Deserialize, Debug)]
pub(crate) struct PutOTPAEADKeyCommand {
pub params: PutObjectParams,
pub data: Vec<u8>,
}
impl Command for PutOTPAEADKeyCommand {
type ResponseType = PutOTPAEADKeyResponse;
}
#[derive(Serialize, Deserialize, Debug)]
pub(crate) struct PutOTPAEADKeyResponse {
pub key_id: ObjectId,
}
impl Response for PutOTPAEADKeyResponse {
const COMMAND_TYPE: CommandType = CommandType::PutOTPAEAD;
}