pub enum CodeRequirementExpression<'a> {
Show 24 variants
False,
True,
Identifier(Cow<'a, str>),
AnchorApple,
AnchorCertificateHash(i32, Cow<'a, [u8]>),
InfoKeyValueLegacy(Cow<'a, str>, Cow<'a, str>),
And(Box<CodeRequirementExpression<'a>>, Box<CodeRequirementExpression<'a>>),
Or(Box<CodeRequirementExpression<'a>>, Box<CodeRequirementExpression<'a>>),
CodeDirectoryHash(Cow<'a, [u8]>),
Not(Box<CodeRequirementExpression<'a>>),
InfoPlistKeyField(Cow<'a, str>, CodeRequirementMatchExpression<'a>),
CertificateField(i32, Cow<'a, str>, CodeRequirementMatchExpression<'a>),
CertificateTrusted(i32),
AnchorTrusted,
CertificateGeneric(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>),
AnchorAppleGeneric,
EntitlementsKey(Cow<'a, str>, CodeRequirementMatchExpression<'a>),
CertificatePolicy(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>),
NamedAnchor(Cow<'a, str>),
NamedCode(Cow<'a, str>),
Platform(u32),
Notarized,
CertificateFieldDate(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>),
LegacyDeveloperId,
}
Expand description
Defines a code requirement expression.
Variants
False
False
false
No payload.
True
True
true
No payload.
Identifier(Cow<'a, str>)
Signing identifier.
identifier <string>
4 bytes length followed by C string.
AnchorApple
The certificate chain must lead to an Apple root.
anchor apple
No payload.
AnchorCertificateHash(i32, Cow<'a, [u8]>)
The certificate chain must anchor to a certificate with specified SHA-1 hash.
anchor <slot> H"<hash>"
4 bytes slot number, 4 bytes hash length, hash value.
InfoKeyValueLegacy(Cow<'a, str>, Cow<'a, str>)
Info.plist key value (legacy).
info[<key>] = <value>
2 pairs of (length + value).
And(Box<CodeRequirementExpression<'a>>, Box<CodeRequirementExpression<'a>>)
Logical and.
expr0 and expr1
Payload consists of 2 sub-expressions with no additional encoding.
Or(Box<CodeRequirementExpression<'a>>, Box<CodeRequirementExpression<'a>>)
Logical or.
expr0 or expr1
Payload consists of 2 sub-expressions with no additional encoding.
CodeDirectoryHash(Cow<'a, [u8]>)
Code directory hash.
`cdhash H“
4 bytes length followed by raw digest value.
Not(Box<CodeRequirementExpression<'a>>)
Logical not.
!expr
Payload is 1 sub-expression.
InfoPlistKeyField(Cow<'a, str>, CodeRequirementMatchExpression<'a>)
Info plist key field.
info [key] match expression
e.g. info [CFBundleName] exists
4 bytes key length, key string, then match expression.
CertificateField(i32, Cow<'a, str>, CodeRequirementMatchExpression<'a>)
Certificate field matches.
certificate <slot> [<field>] match expression
Slot i32, 4 bytes field length, field string, then match expression.
CertificateTrusted(i32)
Certificate in position is trusted for code signing.
certificate <position> trusted
4 bytes certificate position.
AnchorTrusted
The certificate chain must lead to a trusted root.
anchor trusted
No payload.
CertificateGeneric(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>)
Certificate field matches by OID.
certificate <slot> [field.<oid>] match expression
Slot i32, 4 bytes OID length, OID raw bytes, match expression.
AnchorAppleGeneric
For code signed by Apple, including from code signing certificates issued by Apple.
anchor apple generic
No payload.
EntitlementsKey(Cow<'a, str>, CodeRequirementMatchExpression<'a>)
Value associated with specified key in signature’s embedded entitlements dictionary.
entitlement [<key>] match expression
4 bytes key length, key bytes, match expression.
CertificatePolicy(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>)
OID associated with certificate in a given slot.
It is unknown what the OID means.
certificate <slot> [policy.<oid>] match expression
NamedAnchor(Cow<'a, str>)
A named Apple anchor.
anchor apple <name>
4 bytes name length, name bytes.
NamedCode(Cow<'a, str>)
Named code.
(<name>)
4 bytes name length, name bytes.
Platform(u32)
Platform value.
platform = <value>
Payload is a u32.
Notarized
Binary is notarized.
notarized
No Payload.
CertificateFieldDate(i32, Oid<&'a [u8]>, CodeRequirementMatchExpression<'a>)
Certificate field date.
Unknown what the OID corresponds to.
certificate <slot> [timestamp.<oid>] match expression
LegacyDeveloperId
Legacy developer ID used.
Implementations
sourceimpl<'a> CodeRequirementExpression<'a>
impl<'a> CodeRequirementExpression<'a>
sourcepub fn from_bytes(
data: &'a [u8]
) -> Result<(Self, &'a [u8]), AppleCodesignError>
pub fn from_bytes(
data: &'a [u8]
) -> Result<(Self, &'a [u8]), AppleCodesignError>
Construct an expression element by reading from a slice.
Returns the newly constructed element and remaining data in the slice.
Trait Implementations
sourceimpl<'a> Clone for CodeRequirementExpression<'a>
impl<'a> Clone for CodeRequirementExpression<'a>
sourcefn clone(&self) -> CodeRequirementExpression<'a>
fn clone(&self) -> CodeRequirementExpression<'a>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl<'a> Debug for CodeRequirementExpression<'a>
impl<'a> Debug for CodeRequirementExpression<'a>
sourceimpl<'a> Display for CodeRequirementExpression<'a>
impl<'a> Display for CodeRequirementExpression<'a>
sourceimpl<'a> PartialEq<CodeRequirementExpression<'a>> for CodeRequirementExpression<'a>
impl<'a> PartialEq<CodeRequirementExpression<'a>> for CodeRequirementExpression<'a>
sourcefn eq(&self, other: &CodeRequirementExpression<'a>) -> bool
fn eq(&self, other: &CodeRequirementExpression<'a>) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &CodeRequirementExpression<'a>) -> bool
fn ne(&self, other: &CodeRequirementExpression<'a>) -> bool
This method tests for !=
.
impl<'a> StructuralPartialEq for CodeRequirementExpression<'a>
Auto Trait Implementations
impl<'a> RefUnwindSafe for CodeRequirementExpression<'a>
impl<'a> Send for CodeRequirementExpression<'a>
impl<'a> Sync for CodeRequirementExpression<'a>
impl<'a> Unpin for CodeRequirementExpression<'a>
impl<'a> UnwindSafe for CodeRequirementExpression<'a>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more