pub struct PreKeyMessage { /* private fields */ }
Expand description

An encrypted Olm pre-key message.

Contains metadata that is required to establish a Session and a normal Olm Message.

Implementations

The single-use key that was uploaded to a public key directory by the receiver of the message. Should be used to establish a Session.

The base key, a single use key that was created just in time by the sender of the message. Should be used to establish a Session.

The long term identity key of the sender of the message. Should be used to establish a Session

The collection of all keys required for establishing an Olm Session from this pre-key message.

Other methods on this struct (like PreKeyMessage::identity_key()) can be used to retrieve individual keys from this collection.

The actual message that contains the ciphertext.

Try to decode the given byte slice as a Olm Message.

The expected format of the byte array is described in the PreKeyMessage::to_bytes() method.

Encode the PreKeyMessage as an array of bytes.

Olm PreKeyMessages consist of a one-byte version, followed by a variable length payload.

+--------------+------------------------------------+
| Version Byte | Payload Bytes                      |
+--------------+------------------------------------+

The payload uses a format based on the Protocol Buffers encoding. It consists of the following key-value pairs:

NameTagTypeMeaning
One-Time-Key0x0AStringThe public part of Bob’s single-use key
Base-Key0x12StringThe public part of Alice’s single-use key
Identity-Key0x1AStringThe public part of Alice’s identity key
Message0x22StringAn embedded Olm message

The last key/value pair in a PreKeyMessage is a normal Olm Message.

Try to decode the given string as a Olm PreKeyMessage.

The string needs to be a base64 encoded byte array that follows the format described in the PreKeyMessage::to_bytes() method.

Encode the PreKeyMessage as a string.

This method first calls PreKeyMessage::to_bytes() and then encodes the resulting byte array as a string using base64 encoding.

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Deserialize this value from the given Serde deserializer. Read more

Converts to this type from the input type.

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Serialize this value into the given Serde serializer. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

Should always be Self

The resulting type after obtaining ownership.

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

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

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.