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
//! 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 crate::packet;
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
///
/// # A note on equality
///
/// An unprocessed (encrypted) `SEIP` packet is never considered equal
/// to a processed (decrypted) one. Likewise, a processed (decrypted)
/// packet is never considered equal to a structured (parsed) one.
// IMPORTANT: If you add fields to this struct, you need to explicitly
// IMPORTANT: implement PartialEq, Eq, and Hash.
#[derive(Clone, Debug, PartialEq, Eq, Hash)]
pub struct SEIP1 {
/// CTB packet header fields.
pub(crate) common: packet::Common,
/// This is a container packet.
container: packet::Container,
}
assert_send_and_sync!(SEIP1);
impl std::ops::Deref for SEIP1 {
type Target = packet::Container;
fn deref(&self) -> &Self::Target {
&self.container
}
}
impl std::ops::DerefMut for SEIP1 {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.container
}
}
#[allow(clippy::new_without_default)]
impl SEIP1 {
/// Creates a new SEIP1 packet.
pub fn new() -> Self {
Self {
common: Default::default(),
container: 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())
}
}