Struct PingResponse

Source
pub struct PingResponse {
    pub pk: PublicKey,
    pub nonce: Nonce,
    pub payload: Vec<u8>,
}
Expand description

Ping response packet struct. When PingRequest is received DHT node should respond with PingResponse that contains the same ping id inside it’s encrypted payload as it got from PingRequest.

https://zetok.github.io/tox-spec/#dht-packet

LengthContent
10x01
32Public Key
24Nonce
25Payload

where Payload is encrypted PingResponsePayload

Fields§

§pk: PublicKey

public key used for payload encryption

§nonce: Nonce

one time serial number

§payload: Vec<u8>

encrypted payload

Implementations§

Source§

impl PingResponse

Source

pub fn new( shared_secret: &PrecomputedKey, pk: &PublicKey, payload: &PingResponsePayload, ) -> PingResponse

create new PingResponse object

Source

pub fn get_payload( &self, shared_secret: &PrecomputedKey, ) -> Result<PingResponsePayload, GetPayloadError>

Decrypt payload and try to parse it as PingResponsePayload.

Returns Error in case of failure:

  • fails to decrypt
  • fails to parse as given packet type

Trait Implementations§

Source§

impl Clone for PingResponse

Source§

fn clone(&self) -> PingResponse

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 Debug for PingResponse

Source§

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

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

impl FromBytes for PingResponse

Source§

fn from_bytes(i: &[u8]) -> IResult<&[u8], PingResponse, (&[u8], ErrorKind)>

Deserialize struct using nom from raw bytes
Source§

impl PartialEq for PingResponse

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl ToBytes for PingResponse

Source§

fn to_bytes<'a>( &self, buf: (&'a mut [u8], usize), ) -> Result<(&'a mut [u8], usize), GenError>

Serialize struct into raw bytes using cookie_factory
Source§

impl Eq for PingResponse

Source§

impl StructuralPartialEq for PingResponse

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
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,

Source§

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>,

Source§

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>,

Source§

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.