pub struct MsgEcdsaSignatureDepB {
    pub sender_id: Option<u16>,
    pub flags: u8,
    pub stream_counter: u8,
    pub on_demand_counter: u8,
    pub certificate_id: [u8; 4],
    pub n_signature_bytes: u8,
    pub signature: [u8; 72],
    pub signed_messages: Vec<u8>,
}
Expand description

Deprecated

Deprecated.

Fields§

§sender_id: Option<u16>

The message sender_id

§flags: u8

Describes the format of the signed\_messages field below.

§stream_counter: u8

Signature message counter. Zero indexed and incremented with each signature message. The counter will not increment if this message was in response to an on demand request. The counter will roll over after 256 messages. Upon connection, the value of the counter may not initially be zero.

§on_demand_counter: u8

On demand message counter. Zero indexed and incremented with each signature message sent in response to an on demand message. The counter will roll over after 256 messages. Upon connection, the value of the counter may not initially be zero.

§certificate_id: [u8; 4]

The last 4 bytes of the certificate’s SHA-1 fingerprint

§n_signature_bytes: u8

Number of bytes to use of the signature field. The DER encoded signature has a maximum size of 72 bytes but can vary between 70 and 72 bytes in length.

§signature: [u8; 72]

DER encoded ECDSA signature for the messages using SHA-256 as the digest algorithm.

§signed_messages: Vec<u8>

CRCs of the messages covered by this signature. For Skylark, which delivers SBP messages wrapped in Swift’s proprietary RTCM message, these are the 24-bit CRCs from the RTCM message framing. For SBP only streams, this will be 16-bit CRCs from the SBP framing. See the flags field to determine the type of CRCs covered.

Implementations§

source§

impl MsgEcdsaSignatureDepB

source

pub fn crc_type(&self) -> Result<CrcType, u8>

Gets the CrcType stored in the flags bitfield.

Returns Ok if the bitrange contains a known CrcType variant. Otherwise the value of the bitrange is returned as an Err(u8). This may be because of a malformed message, or because new variants of CrcType were added.

source

pub fn set_crc_type(&mut self, crc_type: CrcType)

Set the bitrange corresponding to the CrcType of the flags bitfield.

Trait Implementations§

source§

impl Clone for MsgEcdsaSignatureDepB

source§

fn clone(&self) -> MsgEcdsaSignatureDepB

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl ConcreteMessage for MsgEcdsaSignatureDepB

source§

const MESSAGE_TYPE: u16 = 3_079u16

The message type.
source§

const MESSAGE_NAME: &'static str = "MSG_ECDSA_SIGNATURE_DEP_B"

The message name.
source§

impl Debug for MsgEcdsaSignatureDepB

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for MsgEcdsaSignatureDepB

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl FriendlyName for MsgEcdsaSignatureDepB

source§

fn friendly_name() -> &'static str

source§

impl From<MsgEcdsaSignatureDepB> for Sbp

source§

fn from(msg: MsgEcdsaSignatureDepB) -> Self

Converts to this type from the input type.
source§

impl PartialEq for MsgEcdsaSignatureDepB

source§

fn eq(&self, other: &MsgEcdsaSignatureDepB) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl SbpMessage for MsgEcdsaSignatureDepB

source§

fn message_name(&self) -> &'static str

Get the message name.
source§

fn message_type(&self) -> Option<u16>

Get the message type.
source§

fn sender_id(&self) -> Option<u16>

Get the sender_id if it is set.
source§

fn set_sender_id(&mut self, new_id: u16)

Set the sender id.
source§

fn encoded_len(&self) -> usize

Number of bytes this message will take on the wire.
source§

fn is_valid(&self) -> bool

Tells you if the message is valid or if it is not a valid message and may need to be special cased at certain points.
source§

fn into_valid_msg(self) -> Result<Self, Invalid>

source§

fn gps_time(&self) -> Option<Result<MessageTime, GpsTimeError>>

Get the GPS time associated with the message.
source§

fn friendly_name(&self) -> &'static str

Get friendly name associated with the message.
source§

impl Serialize for MsgEcdsaSignatureDepB

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl TryFrom<Sbp> for MsgEcdsaSignatureDepB

§

type Error = TryFromSbpError

The type returned in the event of a conversion error.
source§

fn try_from(msg: Sbp) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl StructuralPartialEq for MsgEcdsaSignatureDepB

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> Event for T
where T: ConcreteMessage,

source§

const MESSAGE_TYPES: &'static [u16] = const MESSAGE_TYPES: &'static [u16] = &[T::MESSAGE_TYPE];

The message types that correspond to this event. An empty slice means all messages.
source§

fn from_sbp(msg: Sbp) -> T

Create an instance of this event from an SBP message. This message will only be called if the message type is in Event::MESSAGE_TYPES.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,