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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
use std::fmt;
use enum_primitive::FromPrimitive;
use rusticata_macros::debug::HexSlice;
use ikev2::*;
use ikev2_notify::Notify;
use ikev2_transforms::*;
impl<'a> fmt::Debug for IkeV2RawTransform<'a> {
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
let (tf_type, tf_id) = match IkeTransformType::from_u8(self.transform_type) {
Some(IkeTransformType::EncryptionAlgorithm) => {
let id = match IkeTransformEncType::from_u16(self.transform_id) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown encryption {}>", self.transform_id),
};
("EncryptionAlgorithm".to_string(),id)
},
Some(IkeTransformType::PseudoRandomFunction) => {
let id = match IkeTransformPRFType::from_u16(self.transform_id) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown PRF {}>", self.transform_id),
};
("PseudoRandomFunction".to_string(),id)
},
Some(IkeTransformType::IntegrityAlgorithm) => {
let id = match IkeTransformAuthType::from_u16(self.transform_id) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown Auth {}>", self.transform_id),
};
("IntegrityAlgorithm".to_string(),id)
},
Some(IkeTransformType::DiffieHellmanGroup) => {
let id = match IkeTransformDHType::from_u16(self.transform_id) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown DH group {}>", self.transform_id),
};
("DiffieHellmanGroup".to_string(),id)
},
Some(IkeTransformType::ExtendedSequenceNumbers) => {
let id = match IkeTransformESNType::from_u16(self.transform_id) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown ESN value {}>", self.transform_id),
};
("ExtendedSequenceNumbers".to_string(),id)
},
None => (format!("<Unknown transform type {}>", self.transform_type),"".to_string()),
};
fmt.debug_struct("IkeV2RawTransform")
.field("last", &self.last)
.field("reserved1", &self.reserved1)
.field("transform_length", &self.transform_length)
.field("transform_type", &tf_type)
.field("reserved2", &self.reserved2)
.field("transform_id", &tf_id)
.field("attributes", &self.attributes)
.finish()
}
}
impl<'a> fmt::Debug for NoncePayload<'a> {
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
fmt.debug_struct("NoncePayload")
.field("nonce_data", &HexSlice{d:self.nonce_data})
.finish()
}
}
impl<'a> fmt::Debug for NotifyPayload<'a> {
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
let notify_type = match Notify::from_u16(self.notify_type) {
Some(v) => format!("{:?}", v),
_ => format!("<Unknown notify type {}>", self.notify_type),
};
fmt.debug_struct("NotifyPayload")
.field("protocol_id", &self.protocol_id)
.field("spi_size", &self.spi_size)
.field("notify_type", ¬ify_type)
.field("spi", &self.spi)
.field("notify_data", &self.notify_data.map(|o|{HexSlice{d:o}}))
.finish()
}
}