pub struct EmbeddedSignature<'a> {
pub magic: CodeSigningMagic,
pub length: u32,
pub count: u32,
pub data: &'a [u8],
pub blobs: Vec<BlobEntry<'a>>,
}
Expand description
Represents Apple’s common embedded code signature data structures.
This type represents a lightly parsed SuperBlob
with CodeSigningMagic::EmbeddedSignature.
It is the most common embedded signature data format you are likely to encounter.
Fields§
§magic: CodeSigningMagic
Magic value from header.
length: u32
Length of this super blob.
count: u32
Number of blobs in this super blob.
data: &'a [u8]
Raw data backing this super blob.
blobs: Vec<BlobEntry<'a>>
All the blobs within this super blob.
Implementations§
source§impl<'a> EmbeddedSignature<'a>
impl<'a> EmbeddedSignature<'a>
sourcepub fn from_bytes(data: &'a [u8]) -> Result<Self, AppleCodesignError>
pub fn from_bytes(data: &'a [u8]) -> Result<Self, AppleCodesignError>
Attempt to parse an embedded signature super blob from data.
The argument to this function is likely the subset of the
__LINKEDIT
Mach-O section that the LC_CODE_SIGNATURE
load instructions
points it.
sourcepub fn find_slot(&self, slot: CodeSigningSlot) -> Option<&BlobEntry<'a>>
pub fn find_slot(&self, slot: CodeSigningSlot) -> Option<&BlobEntry<'a>>
Find the first occurrence of the specified slot.
pub fn find_slot_parsed( &self, slot: CodeSigningSlot ) -> Result<Option<ParsedBlob<'a>>, AppleCodesignError>
sourcepub fn code_directory(
&self
) -> Result<Option<Box<CodeDirectoryBlob<'a>>>, AppleCodesignError>
pub fn code_directory( &self ) -> Result<Option<Box<CodeDirectoryBlob<'a>>>, AppleCodesignError>
Attempt to resolve the primary CodeDirectoryBlob
for this signature data.
Returns Err on data parsing error or if the blob slot didn’t contain a code directory.
Returns Ok(None)
if there is no code directory slot.
sourcepub fn alternate_code_directories(
&self
) -> Result<Vec<(CodeSigningSlot, Box<CodeDirectoryBlob<'a>>)>, AppleCodesignError>
pub fn alternate_code_directories( &self ) -> Result<Vec<(CodeSigningSlot, Box<CodeDirectoryBlob<'a>>)>, AppleCodesignError>
Obtain code directories occupying alternative slots.
Embedded signatures set aside a few slots for alternate code directory data structures. This method will resolve any that are present.
sourcepub fn all_code_directories(
&self
) -> Result<Vec<(CodeSigningSlot, Box<CodeDirectoryBlob<'a>>)>, AppleCodesignError>
pub fn all_code_directories( &self ) -> Result<Vec<(CodeSigningSlot, Box<CodeDirectoryBlob<'a>>)>, AppleCodesignError>
Resolve all code directories in this signature.
sourcepub fn code_directory_for_digest(
&self,
digest: DigestType
) -> Result<Option<Box<CodeDirectoryBlob<'a>>>, AppleCodesignError>
pub fn code_directory_for_digest( &self, digest: DigestType ) -> Result<Option<Box<CodeDirectoryBlob<'a>>>, AppleCodesignError>
Attempt to resolve a code directory containing digests of the specified type.
sourcepub fn preferred_code_directory(
&self
) -> Result<Box<CodeDirectoryBlob<'a>>, AppleCodesignError>
pub fn preferred_code_directory( &self ) -> Result<Box<CodeDirectoryBlob<'a>>, AppleCodesignError>
Attempt to resolve the preferred code directory for this binary.
Attempts to resolve the SHA-256 variant first, falling back to SHA-1 on failure, and falling back to the primary CD slot before erroring if no CD is present.
sourcepub fn entitlements(
&self
) -> Result<Option<Box<EntitlementsBlob<'a>>>, AppleCodesignError>
pub fn entitlements( &self ) -> Result<Option<Box<EntitlementsBlob<'a>>>, AppleCodesignError>
Attempt to resolve a parsed EntitlementsBlob for this signature data.
Returns Err on data parsing error or if the blob slot didn’t contain an entitlments blob.
Returns Ok(None)
if there is no entitlements slot.
sourcepub fn code_requirements(
&self
) -> Result<Option<Box<RequirementSetBlob<'a>>>, AppleCodesignError>
pub fn code_requirements( &self ) -> Result<Option<Box<RequirementSetBlob<'a>>>, AppleCodesignError>
Attempt to resolve a parsed RequirementSetBlob for this signature data.
Returns Err on data parsing error or if the blob slot didn’t contain a requirements blob.
Returns Ok(None)
if there is no requirements slot.
sourcepub fn signature_data(&self) -> Result<Option<&'a [u8]>, AppleCodesignError>
pub fn signature_data(&self) -> Result<Option<&'a [u8]>, AppleCodesignError>
Attempt to resolve raw CMS signature data.
The returned data is likely DER PKCS#7 with the root object pkcs7-signedData (1.2.840.113549.1.7.2).
sourcepub fn signed_data(&self) -> Result<Option<SignedData>, AppleCodesignError>
pub fn signed_data(&self) -> Result<Option<SignedData>, AppleCodesignError>
Obtain the parsed CMS SignedData.
Trait Implementations§
source§impl<'a> Debug for EmbeddedSignature<'a>
impl<'a> Debug for EmbeddedSignature<'a>
source§impl<'a> TryFrom<EmbeddedSignature<'a>> for CodeSignature
impl<'a> TryFrom<EmbeddedSignature<'a>> for CodeSignature
§type Error = AppleCodesignError
type Error = AppleCodesignError
Auto Trait Implementations§
impl<'a> RefUnwindSafe for EmbeddedSignature<'a>
impl<'a> Send for EmbeddedSignature<'a>
impl<'a> Sync for EmbeddedSignature<'a>
impl<'a> Unpin for EmbeddedSignature<'a>
impl<'a> UnwindSafe for EmbeddedSignature<'a>
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere T: 'a,
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where &'a Self: for<'a> IntoIterator,
§impl<T> Identity for Twhere
T: ?Sized,
impl<T> Identity for Twhere T: ?Sized,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere
Self: Borrow<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere Self: Borrow<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R
) -> Rwhere
Self: BorrowMut<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> Rwhere Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere
Self: AsRef<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere Self: AsRef<U>, U: 'a + ?Sized, R: 'a,
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere
Self: AsMut<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere Self: AsMut<U>, U: 'a + ?Sized, R: 'a,
self
, then passes self.as_mut()
into the pipe
function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere
Self: Deref<Target = T>,
T: ?Sized,
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere
Self: DerefMut<Target = T> + Deref,
T: ?Sized,
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
.tap_ref_mut()
only in debug builds, and is erased in release
builds.