Skip to main content

Signal

Struct Signal 

Source
pub struct Signal<'a> { /* private fields */ }
Expand description

Feature handle for Signal protocol operations.

Implementations§

Source§

impl<'a> Signal<'a>

Source

pub async fn encrypt_message( &self, jid: &Jid, plaintext: &[u8], ) -> Result<(EncType, Vec<u8>)>

Encrypt plaintext for a single recipient using the Signal protocol.

Returns (EncType, ciphertext_bytes). The caller is responsible for padding if needed; this method encrypts raw bytes.

PN JIDs are resolved to LID when a LID session exists, matching the internal send path.

Source

pub async fn decrypt_message( &self, jid: &Jid, enc_type: EncType, ciphertext: &[u8], ) -> Result<Vec<u8>>

Decrypt a Signal protocol message from a sender.

Returns raw padded plaintext. Use MessageUtils::unpad_message_ref with the stanza’s v attribute if WhatsApp message unpadding is needed.

PN JIDs are resolved to LID when a LID session exists, matching the internal receive path.

Source

pub async fn encrypt_group_message( &self, group_jid: &Jid, plaintext: &[u8], ) -> Result<(Option<Vec<u8>>, Vec<u8>)>

Encrypt plaintext for a group using sender keys.

Returns (Option<skdm_bytes>, ciphertext_bytes). The SKDM is Some only when a new sender key was created (first encrypt for this group or after key rotation). Callers must distribute the SKDM to all group participants when present. This matches WA Web which only creates SKDM on first group encrypt or after sender key rotation.

Not safe to call concurrently with decrypt_group_message for the same group — sender key state is not internally locked.

Source

pub async fn decrypt_group_message( &self, group_jid: &Jid, sender_jid: &Jid, ciphertext: &[u8], ) -> Result<Vec<u8>>

Decrypt a group (sender-key) message.

Returns raw padded plaintext. Use MessageUtils::unpad_message_ref with the stanza’s v attribute if WhatsApp message unpadding is needed.

Not safe to call concurrently with encrypt_group_message for the same group — sender key state is not internally locked.

Source

pub async fn validate_session(&self, jid: &Jid) -> Result<bool>

Check whether a Signal session exists for jid.

PN JIDs are resolved to LID when a LID mapping exists, matching the encrypt/decrypt paths.

Source

pub async fn delete_sessions(&self, jids: &[Jid]) -> Result<()>

Delete Signal sessions and identity keys for the given JIDs.

Matches WA Web’s deleteRemoteSession which removes both session and identity as a paired operation. Changes are flushed to the persistent backend before returning.

PN JIDs are resolved to LID when a LID mapping exists, matching the encrypt/decrypt paths.

Source

pub async fn create_participant_nodes( &self, recipient_jids: &[Jid], message: &Message, ) -> Result<(Vec<Node>, bool)>

Create encrypted participant <to> nodes for the given recipient JIDs.

Resolves devices, ensures Signal sessions, encrypts the message for each device, and returns the resulting XML nodes.

Returns (nodes, should_include_device_identity).

Source

pub async fn assert_sessions(&self, jids: &[Jid]) -> Result<()>

Ensure E2E sessions exist for the given JIDs.

Source

pub async fn get_user_devices(&self, jids: &[Jid]) -> Result<Vec<Jid>>

Get all known device JIDs for the given user JIDs via usync.

Auto Trait Implementations§

§

impl<'a> Freeze for Signal<'a>

§

impl<'a> !RefUnwindSafe for Signal<'a>

§

impl<'a> Send for Signal<'a>

§

impl<'a> Sync for Signal<'a>

§

impl<'a> Unpin for Signal<'a>

§

impl<'a> UnsafeUnpin for Signal<'a>

§

impl<'a> !UnwindSafe for Signal<'a>

Blanket Implementations§

Source§

impl<T> AggregateExpressionMethods for T

Source§

fn aggregate_distinct(self) -> Self::Output
where Self: DistinctDsl,

DISTINCT modifier for aggregate functions Read more
Source§

fn aggregate_all(self) -> Self::Output
where Self: AllDsl,

ALL modifier for aggregate functions Read more
Source§

fn aggregate_filter<P>(self, f: P) -> Self::Output
where P: AsExpression<Bool>, Self: FilterDsl<<P as AsExpression<Bool>>::Expression>,

Add an aggregate function filter Read more
Source§

fn aggregate_order<O>(self, o: O) -> Self::Output
where Self: OrderAggregateDsl<O>,

Add an aggregate function order Read more
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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSend for T
where T: Any + Send,

Source§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Send + Sync>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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> IntoSql for T

Source§

fn into_sql<T>(self) -> Self::Expression

Convert self to an expression for Diesel’s query builder. Read more
Source§

fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
where &'a Self: AsExpression<T>, T: SqlType + TypedExpressionType,

Convert &self to an expression for Diesel’s query builder. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

impl<T> WindowExpressionMethods for T

Source§

fn over(self) -> Self::Output
where Self: OverDsl,

Turn a function call into a window function call Read more
Source§

fn window_filter<P>(self, f: P) -> Self::Output
where P: AsExpression<Bool>, Self: FilterDsl<<P as AsExpression<Bool>>::Expression>,

Add a filter to the current window function Read more
Source§

fn partition_by<E>(self, expr: E) -> Self::Output
where Self: PartitionByDsl<E>,

Add a partition clause to the current window function Read more
Source§

fn window_order<E>(self, expr: E) -> Self::Output
where Self: OrderWindowDsl<E>,

Add a order clause to the current window function Read more
Source§

fn frame_by<E>(self, expr: E) -> Self::Output
where Self: FrameDsl<E>,

Add a frame clause to the current window function Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,