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§
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 entitlements_der(
&self,
) -> Result<Option<Box<EntitlementsDerBlob<'a>>>, AppleCodesignError>
pub fn entitlements_der( &self, ) -> Result<Option<Box<EntitlementsDerBlob<'a>>>, AppleCodesignError>
Attempt to resolve a parsed EntitlementsDerBlob for this signature.
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 launch_constraints_self(
&self,
) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
pub fn launch_constraints_self( &self, ) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
Obtain the launch constraints on self blob.
Sourcepub fn launch_constraints_parent(
&self,
) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
pub fn launch_constraints_parent( &self, ) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
Obtain the launch constraints on parent blob.
Sourcepub fn launch_constraints_responsible(
&self,
) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
pub fn launch_constraints_responsible( &self, ) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
Obtain the launch constraints on responsible process blob.
Sourcepub fn library_constraints(&self) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
pub fn library_constraints(&self) -> Result<Option<Box<ConstraintsDerBlob<'a>>>>
Obtain the library constraints blob.
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
Source§type Error = AppleCodesignError
type Error = AppleCodesignError
Auto Trait Implementations§
impl<'a> Freeze for EmbeddedSignature<'a>
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§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§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
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
Source§impl<T> Identity for Twhere
T: ?Sized,
impl<T> Identity for Twhere
T: ?Sized,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§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 moreSource§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 moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§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.Source§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.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.