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
|
//! Symmetrically Encrypted Integrity Protected data packets.
//!
//! An encrypted data packet is a container. See [Section 5.13 of RFC
//! 4880] for details.
//!
//! [Section 5.13 of RFC 4880]: https://tools.ietf.org/html/rfc4880#section-5.13
use std::ops::{Deref, DerefMut};
use crate::packet::{self, Common};
use crate::Packet;
/// Holds an encrypted data packet.
///
/// An encrypted data packet is a container. See [Section 5.13 of RFC
/// 4880] for details.
///
/// [Section 5.13 of RFC 4880]: https://tools.ietf.org/html/rfc4880#section-5.13
#[derive(PartialEq, Eq, Hash, Clone, Debug)]
pub struct SEIP1 {
/// CTB packet header fields.
pub(crate) common: packet::Common,
}
impl SEIP1 {
/// Creates a new SEIP1 packet.
pub fn new() -> Self {
Self {
common: Default::default(),
}
}
}
impl From<SEIP1> for super::SEIP {
fn from(p: SEIP1) -> Self {
super::SEIP::V1(p)
}
}
impl From<SEIP1> for Packet {
fn from(s: SEIP1) -> Self {
Packet::SEIP(s.into())
}
}
// Allow transparent access of common fields.
impl<'a> Deref for SEIP1 {
type Target = Common;
fn deref(&self) -> &Self::Target {
&self.common
}
}
// Allow transparent access of common fields.
impl<'a> DerefMut for SEIP1 {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.common
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn deref() {
let mut s = SEIP1 {
common: Default::default(),
};
assert_eq!(s.body(), None);
s.set_body(vec![0, 1, 2]);
assert_eq!(s.body(), Some(&[0, 1, 2][..]));
}
}
|