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: CodeSigningMagicMagic value from header.
length: u32Length of this super blob.
count: u32Number 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
sourceimpl<'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 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
sourceimpl<'a> Debug for EmbeddedSignature<'a>
impl<'a> Debug for EmbeddedSignature<'a>
sourceimpl<'a> TryFrom<EmbeddedSignature<'a>> for CodeSignature
impl<'a> TryFrom<EmbeddedSignature<'a>> for CodeSignature
type Error = AppleCodesignError
type Error = AppleCodesignError
sourcefn try_from(sig: EmbeddedSignature<'a>) -> Result<Self, Self::Error>
fn try_from(sig: EmbeddedSignature<'a>) -> Result<Self, Self::Error>
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
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut 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,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
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>
impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
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 morefn 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 morefn 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,
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> Rwhere
Self: Deref<Target = T>,
T: 'a + ?Sized,
R: 'a,
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> Rwhere
Self: Deref<Target = T>,
T: 'a + ?Sized,
R: 'a,
self, then passes self.deref() 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 morefn 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 morefn 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 morefn 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 morefn 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 morefn 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 morefn 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. Read morefn 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. Read morefn 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. Read morefn 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. Read morefn 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. Read more