breez_sdk_liquid::lightning_125::onion_message::messenger

Trait CustomOnionMessageHandler

pub trait CustomOnionMessageHandler {
    type CustomMessage: OnionMessageContents;

    // Required methods
    fn handle_custom_message(
        &self,
        message: Self::CustomMessage,
        context: Option<Vec<u8>>,
        responder: Option<Responder>,
    ) -> Option<(Self::CustomMessage, ResponseInstruction)>;
    fn read_custom_message<R>(
        &self,
        message_type: u64,
        buffer: &mut R,
    ) -> Result<Option<Self::CustomMessage>, DecodeError>
       where R: Read;
    fn release_pending_custom_messages(
        &self,
    ) -> Vec<(Self::CustomMessage, MessageSendInstructions)>;
}
Expand description

Handler for custom onion messages. If you are using SimpleArcOnionMessenger, SimpleRefOnionMessenger, or prefer to ignore inbound custom onion messages, IgnoringMessageHandler must be provided to OnionMessenger::new. Otherwise, a custom implementation of this trait must be provided, with CustomMessage specifying the supported message types.

See OnionMessenger for example usage.

Required Associated Types§

type CustomMessage: OnionMessageContents

The message known to the handler. To support multiple message types, you may want to make this an enum with a variant for each supported message.

Required Methods§

fn handle_custom_message( &self, message: Self::CustomMessage, context: Option<Vec<u8>>, responder: Option<Responder>, ) -> Option<(Self::CustomMessage, ResponseInstruction)>

Called with the custom message that was received, returning a response to send, if any.

The returned Self::CustomMessage, if any, is enqueued to be sent by OnionMessenger.

fn read_custom_message<R>( &self, message_type: u64, buffer: &mut R, ) -> Result<Option<Self::CustomMessage>, DecodeError>
where R: Read,

Read a custom message of type message_type from buffer, returning Ok(None) if the message type is unknown.

fn release_pending_custom_messages( &self, ) -> Vec<(Self::CustomMessage, MessageSendInstructions)>

Releases any Self::CustomMessages that need to be sent.

Typically, this is used for messages initiating a message flow rather than in response to another message. The latter should use the return value of Self::handle_custom_message.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§