Quoter
Allows getting the expected amount out or amount in for a given swap without executing the swap
These functions are not gas efficient and should not be called on chain. Instead, optimistically execute the swap and check the amounts in the callback.
Functions
constructor
bonsaiswapV3SwapCallback
Called to msg.sender
after executing a swap via IBonsaiswapV3Pool#swap.
In the implementation you must pay the pool tokens owed for the swap. The caller of this method must be checked to be a BonsaiswapV3Pool deployed by the canonical BonsaiswapV3Factory. amount0Delta and amount1Delta can both be 0 if no tokens were swapped.
Parameters:
amount0Delta
int256
The amount of token0 that was sent (negative) or must be received (positive) by the pool by
the end of the swap. If positive, the callback must send that amount of token0 to the pool. |amount1Delta
| int256 | The amount of token1 that was sent (negative) or must be received (positive) by the pool by the end of the swap. If positive, the callback must send that amount of token1 to the pool. |data
| bytes | Any data passed through by the caller via the IBonsaiswapV3PoolActions#swap call
quoteExactInputSingle
Returns the amount out received for a given exact input but for a swap of a single pool
Parameters:
tokenIn
address
The token being swapped in
tokenOut
address
The token being swapped out
fee
uint24
The fee of the token pool to consider for the pair
amountIn
uint256
The desired input amount
sqrtPriceLimitX96
uint160
The price limit of the pool that cannot be exceeded by the swap
Return Values:
amountOut
uint256
The amount of tokenOut
that would be received
quoteExactInput
Returns the amount out received for a given exact input swap without executing the swap
Parameters:
path
bytes
The path of the swap, i.e. each token pair and the pool fee
amountIn
uint256
The amount of the first token to swap
Return Values:
amountOut
uint256
The amount of the last token that would be received
quoteExactOutputSingle
Returns the amount in required to receive the given exact output amount but for a swap of a single pool
Parameters:
tokenIn
address
The token being swapped in
tokenOut
address
The token being swapped out
fee
uint24
The fee of the token pool to consider for the pair
amountOut
uint256
The desired output amount
sqrtPriceLimitX96
uint160
The price limit of the pool that cannot be exceeded by the swap
Return Values:
amountIn
uint256
The amount required as the input for the swap in order to receive amountOut
quoteExactOutput
Returns the amount in required for a given exact output swap without executing the swap
Parameters:
path
bytes
The path of the swap, i.e. each token pair and the pool fee
amountOut
uint256
The amount of the last token to receive
Return Values:
amountIn
uint256
The amount of first token required to be paid
Last updated