OAppAuthSender
Inherits: OAppAuthCore
Abstract contract implementing the OAppSender functionality for sending messages to a LayerZero endpoint.
This Auth version of OAppCore uses solmate's Auth instead of OZ's Ownable for compatibility purposes
State Variables
SENDER_VERSION
Functions
oAppVersion
Retrieves the OApp version information.
Providing 0 as the default for OAppReceiver version. Indicates that the OAppReceiver is not implemented. ie. this is a SEND only OApp.
If the OApp uses both OAppSender and OAppReceiver, then this needs to be override returning the correct versions
Returns
senderVersion
uint64
The version of the OAppSender.sol contract.
receiverVersion
uint64
The version of the OAppReceiver.sol contract.
_quote
Internal function to interact with the LayerZero EndpointV2.quote() for fee calculation.
Parameters
_dstEid
uint32
The destination endpoint ID.
_message
bytes
The message payload.
_options
bytes
Additional options for the message.
_payInLzToken
bool
Flag indicating whether to pay the fee in LZ tokens.
Returns
fee
MessagingFee
The calculated MessagingFee for the message. - nativeFee: The native fee for the message. - lzTokenFee: The LZ token fee for the message.
_lzSend
Internal function to interact with the LayerZero EndpointV2.send() for sending a message.
Parameters
_dstEid
uint32
The destination endpoint ID.
_message
bytes
The message payload.
_options
bytes
Additional options for the message.
_fee
MessagingFee
The calculated LayerZero fee for the message. - nativeFee: The native fee. - lzTokenFee: The lzToken fee.
_refundAddress
address
The address to receive any excess fee values sent to the endpoint.
Returns
receipt
MessagingReceipt
The receipt for the sent message. - guid: The unique identifier for the sent message. - nonce: The nonce of the sent message. - fee: The LayerZero fee incurred for the message.
_payNative
Internal function to pay the native fee associated with the message.
If the OApp needs to initiate MULTIPLE LayerZero messages in a single transaction, this will need to be overridden because msg.value would contain multiple lzFees.
Should be overridden in the event the LayerZero endpoint requires a different native currency.
Some EVMs use an ERC20 as a method for paying transactions/gasFees.
The endpoint is EITHER/OR, ie. it will NOT support both types of native payment at a time.
Parameters
_nativeFee
uint256
The native fee to be paid.
Returns
nativeFee
uint256
The amount of native currency paid.
_payLzToken
Internal function to pay the LZ token fee associated with the message.
If the caller is trying to pay in the specified lzToken, then the lzTokenFee is passed to the endpoint.
Any excess sent, is passed back to the specified _refundAddress in the _lzSend().
Parameters
_lzTokenFee
uint256
The LZ token fee to be paid.