Algebra Integral
HomepageSocialsIntegrate
  • Overview
    • What is Algebra?
    • Who Are These Docs For
    • Why Concentrated Liquidity & Modularity Matter
    • Partners & Ecosystem
    • Audits & Security
    • Social Media & Communities
  • Introducing Algebra Integral to Founders & Business Teams
    • Overview of Algebra Integral
      • How It Works: Core + Plugins
      • V3 vs. V4: Key Differences
      • Integral vs. Uniswap V4: Key Differences
    • Benefits of Modular Architecture
      • Perks for DEXes
      • Perks for Builders
      • Perks for Users
  • Modularity: Use Cases
  • Plugin Marketplace
  • Algebra Partner Support
  • User Guide Template For DEXes
    • Concentrated Liquidity & Modular Architecture Basics
      • Glossary
      • How Concentrated Liquidity & Modular Architecture Work
      • Benefits of Modular Concentrated Liquidity AMM for Users
        • Perks for Liquidity Providers
        • Perks for Projects
        • Perks for Traders
      • Fee Mechanics
        • Static Fee
        • Dynamic Fee
        • Sliding Fee
        • Dynamic Fee Based on Trading Volume
        • Managed Swap Fee
        • Whitelist Fee Discount
      • Farming
      • Farming FAQ
  • Price Ranges and Liquidity Strategies
    • What Are Price Ranges
    • Basic Price Range Presets
    • Advanced Range Presets
    • How Price Moves Affect Liquidity
    • Impermanent Loss: Concepts & Mitigation
    • Matching Your Liquidity Strategy to Market Moves
    • Swap & LP Strategies with Price Ranges
    • Liquidity Scenarios & Risk Profiles
  • Liquidity Provisioning: Tutorials & FAQs
    • Adding Liquidity
      • Manual Mode
      • Automated Mode
    • Managing & Adjusting Positions
    • How APR is Calculated
    • FAQ for LPs
  • Algebra Integral / Technical Reference
    • Intro
    • Audits
    • Integration Process
      • Specification and API of contracts
        • Algebra Pool
        • Algebra Factory
        • Swap Router
        • Nonfungible Position Manager
        • Quoter
        • QuoterV2
        • TickLens
      • Interaction with pools
        • Getting data from pools
      • Subgraphs and analytics
        • Examples of queries
      • Technical Guides
        • Intro
        • Swaps
          • Single swaps
          • Multihop swaps
        • Providing liquidity
          • Setting up your contract
          • Mint a new position
          • Collect fees
          • Decrease liquidity
          • Increase liquidity
          • Final Contract
        • Flashloans
          • Setting up your contract
          • Calling flash
          • Flash callback
          • Final contract
      • Migration from UniswapV3
      • FAQ
    • Core Logic
      • Pool overview
      • Swap calculation
      • Liquidity and positions
      • Ticks
        • Ticks search tree
      • Reserves
      • Flash
      • Plugins
      • AlgebraFactory and roles
    • Plugins
      • Overview
      • Farming
      • Adaptive Fee
      • Sliding Fee
      • Whitelist Discount Fee
      • Safety Switch
      • Position Limit Orders
      • Managed Swap Fee
      • FAQ
    • Guides
      • Plugin Development
      • Plugin Testing
      • Plugin Deployment
    • Changes V1
    • Changes V1.1
    • Changes v1.2
  • Changes v1.2.1
  • Other
    • Archived Documentation
Powered by GitBook
On this page
  • Functions
  • constructor
  • algebraSwapCallback
  • quoteExactInputSingle
  • quoteExactInput
  • quoteExactOutputSingle
  • quoteExactOutput
  1. Algebra Integral / Technical Reference
  2. Integration Process
  3. Specification and API of contracts

Quoter

Provides quotes for swaps

Allows getting the expected amount out or amount in for a given swap without executing the swap

Developer note: 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. Credit to Uniswap Labs under GPL-2.0-or-later license: https://github.com/Uniswap/v3-periphery

Inherits: IQuoter IAlgebraSwapCallback PeripheryImmutableState

Functions

constructor

constructor(address _factory, address _WNativeToken, address _poolDeployer) public
Name
Type
Description

_factory

address

_WNativeToken

address

_poolDeployer

address

algebraSwapCallback

function algebraSwapCallback(int256 amount0Delta, int256 amount1Delta, bytes path) external view

Selector: 0x2c8958f6

Called to `msg.sender` after executing a swap via IAlgebraPool#swap.

Developer note: In the implementation you must pay the pool tokens owed for the swap. The caller of this method must be checked to be a AlgebraPool deployed by the canonical AlgebraFactory. amount0Delta and amount1Delta can both be 0 if no tokens were swapped.

Name
Type
Description

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.

path

bytes

quoteExactInputSingle

function quoteExactInputSingle(address tokenIn, address tokenOut, uint256 amountIn, uint160 limitSqrtPrice) public returns (uint256 amountOut, uint16 fee)

Selector: 0x2d9ebd1d

Returns the amount out received for a given exact input but for a swap of a single pool

Name
Type
Description

tokenIn

address

The token being swapped in

tokenOut

address

The token being swapped out

amountIn

uint256

The desired input amount

limitSqrtPrice

uint160

The price limit of the pool that cannot be exceeded by the swap

Returns:

Name
Type
Description

amountOut

uint256

The amount of tokenOut that would be received

fee

uint16

quoteExactInput

function quoteExactInput(bytes path, uint256 amountIn) external returns (uint256 amountOut, uint16[] fees)

Selector: 0xcdca1753

Returns the amount out received for a given exact input swap without executing the swap

Name
Type
Description

path

bytes

The path of the swap, i.e. each token pair

amountIn

uint256

The amount of the first token to swap

Returns:

Name
Type
Description

amountOut

uint256

The amount of the last token that would be received

fees

uint16[]

quoteExactOutputSingle

function quoteExactOutputSingle(address tokenIn, address tokenOut, uint256 amountOut, uint160 limitSqrtPrice) public returns (uint256 amountIn, uint16 fee)

Selector: 0x9e73c81d

Returns the amount in required to receive the given exact output amount but for a swap of a single pool

Name
Type
Description

tokenIn

address

The token being swapped in

tokenOut

address

The token being swapped out

amountOut

uint256

The desired output amount

limitSqrtPrice

uint160

The price limit of the pool that cannot be exceeded by the swap

Returns:

Name
Type
Description

amountIn

uint256

The amount required as the input for the swap in order to receive amountOut

fee

uint16

quoteExactOutput

function quoteExactOutput(bytes path, uint256 amountOut) external returns (uint256 amountIn, uint16[] fees)

Selector: 0x2f80bb1d

Returns the amount in required for a given exact output swap without executing the swap

Name
Type
Description

path

bytes

The path of the swap, i.e. each token pair. Path must be provided in reverse order

amountOut

uint256

The amount of the last token to receive

Returns:

Name
Type
Description

amountIn

uint256

The amount of first token required to be paid

fees

uint16[]

PreviousNonfungible Position ManagerNextQuoterV2