Enum tugger_apple_codesign::code_requirement::CodeRequirementExpression [−][src]
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
No payload.
True
true
No payload.
Signing identifier.
identifier <string>
4 bytes length followed by C string.
The certificate chain must lead to an Apple root.
anchor apple
No payload.
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.
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.
Tuple Fields of And
0: Box<CodeRequirementExpression<'a>>
1: Box<CodeRequirementExpression<'a>>
Or(Box<CodeRequirementExpression<'a>>, Box<CodeRequirementExpression<'a>>)
Logical or.
expr0 or expr1
Payload consists of 2 sub-expressions with no additional encoding.
Tuple Fields of Or
0: Box<CodeRequirementExpression<'a>>
1: Box<CodeRequirementExpression<'a>>
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.
Tuple Fields of Not
0: Box<CodeRequirementExpression<'a>>
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.
Tuple Fields of InfoPlistKeyField
0: Cow<'a, str>
1: CodeRequirementMatchExpression<'a>
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.
Tuple Fields of CertificateField
CertificateTrusted(i32)
Certificate in position is trusted for code signing.
certificate <position> trusted
4 bytes certificate position.
Tuple Fields of CertificateTrusted
0: i32
The certificate chain must lead to a trusted root.
anchor trusted
No payload.
Certificate field matches by OID.
certificate <slot> [field.<oid>] match expression
Slot i32, 4 bytes OID length, OID raw bytes, match expression.
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.
Tuple Fields of EntitlementsKey
0: Cow<'a, str>
1: CodeRequirementMatchExpression<'a>
OID associated with certificate in a given slot.
It is unknown what the OID means.
certificate <slot> [policy.<oid>] match expression
A named Apple anchor.
anchor apple <name>
4 bytes name length, name bytes.
Named code.
(<name>)
4 bytes name length, name bytes.
Platform(u32)
Platform value.
platform = <value>
Payload is a u32.
Tuple Fields of Platform
0: u32
Binary is notarized.
notarized
No Payload.
Certificate field date.
Unknown what the OID corresponds to.
certificate <slot> [timestamp.<oid>] match expression
Legacy developer ID used.
Implementations
Construct an expression element by reading from a slice.
Returns the newly constructed element and remaining data in the slice.
Write binary representation of this expression to a destination.
Trait Implementations
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
This method tests for !=
.
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
Mutably borrows from an owned value. Read more
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more