Skip to content

Commit

Permalink
x509-cert: restore Copy for Validity (#1527)
Browse files Browse the repository at this point in the history
x509_cert::time::Validity used to have Copy, but because it now carries
a Profile, it may lose the Copy trait

This forces the profile to be copyable. Profile should not carry state
so I don't believe this is much of an issue.
  • Loading branch information
baloo authored Sep 24, 2024
1 parent ac7abc6 commit 37d32ce
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions x509-cert/src/certificate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ use crate::time::Time;
/// [`Profile`] allows the consumer of this crate to customize the behavior when parsing
/// certificates.
/// By default, parsing will be made in a rfc5280-compliant manner.
pub trait Profile: PartialEq + Debug + Eq + Clone + Default + 'static {
pub trait Profile: PartialEq + Debug + Eq + Clone + Copy + Default + 'static {
/// Checks to run when parsing serial numbers
fn check_serial_number(serial: &SerialNumber<Self>) -> der::Result<()> {
// See the note in `SerialNumber::new`: we permit lengths of 21 bytes here,
Expand Down Expand Up @@ -48,15 +48,15 @@ pub trait Profile: PartialEq + Debug + Eq + Clone + Default + 'static {
}

#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
#[derive(Debug, PartialEq, Eq, Clone, Default)]
#[derive(Debug, PartialEq, Eq, Copy, Clone, Default)]
/// Parse and serialize certificates in rfc5280-compliant manner
pub struct Rfc5280;

impl Profile for Rfc5280 {}

#[cfg(feature = "hazmat")]
#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
#[derive(Debug, PartialEq, Eq, Clone, Default)]
#[derive(Debug, PartialEq, Eq, Copy, Clone, Default)]
/// Parse raw x509 certificate and disable all the checks and modification to the underlying data.
pub struct Raw;

Expand Down

0 comments on commit 37d32ce

Please sign in to comment.