# 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[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#functions) <a href="#functions" id="functions"></a>

#### constructor[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#constructor) <a href="#constructor" id="constructor"></a>

```solidity
  function constructor(
  ) public
```

#### dragonswapV2SwapCallback[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#uniswapv3swapcallback) <a href="#uniswapv3swapcallback" id="uniswapv3swapcallback"></a>

```solidity
  function dragonswapV2SwapCallback(
    int256 amount0Delta,
    int256 amount1Delta,
    bytes data
  ) external
```

Called to `msg.sender` after executing a swap via IDragonswapV2Pool#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 DragonswapV2Pool deployed by the canonical DragonswapV2Factory. amount0Delta and amount1Delta can both be 0 if no tokens were swapped.

**Parameters:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#parameters)

| 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. |`data` | bytes | Any data passed through by the caller via the IDragonswapV2PoolActions#swap call

#### quoteExactInputSingle[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#quoteexactinputsingle) <a href="#quoteexactinputsingle" id="quoteexactinputsingle"></a>

```solidity
  function quoteExactInputSingle(
    address tokenIn,
    address tokenOut,
    uint24 fee,
    uint256 amountIn,
    uint160 sqrtPriceLimitX96
  ) public returns (uint256 amountOut)
```

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

**Parameters:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#parameters-1)

| Name                | Type    | Description                                                     |
| ------------------- | ------- | --------------------------------------------------------------- |
| `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:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#return-values)

| Name        | Type    | Description                                     |
| ----------- | ------- | ----------------------------------------------- |
| `amountOut` | uint256 | The amount of `tokenOut` that would be received |

#### quoteExactInput[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#quoteexactinput) <a href="#quoteexactinput" id="quoteexactinput"></a>

```solidity
  function quoteExactInput(
    bytes path,
    uint256 amountIn
  ) external returns (uint256 amountOut)
```

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

**Parameters:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#parameters-2)

| Name       | Type    | Description                                                 |
| ---------- | ------- | ----------------------------------------------------------- |
| `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:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#return-values-1)

| Name        | Type    | Description                                         |
| ----------- | ------- | --------------------------------------------------- |
| `amountOut` | uint256 | The amount of the last token that would be received |

#### quoteExactOutputSingle[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#quoteexactoutputsingle) <a href="#quoteexactoutputsingle" id="quoteexactoutputsingle"></a>

```solidity
  function quoteExactOutputSingle(
    address tokenIn,
    address tokenOut,
    uint24 fee,
    uint256 amountOut,
    uint160 sqrtPriceLimitX96
  ) public returns (uint256 amountIn)
```

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

**Parameters:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#parameters-3)

| Name                | Type    | Description                                                     |
| ------------------- | ------- | --------------------------------------------------------------- |
| `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:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#return-values-2)

| Name       | Type    | Description                                                                   |
| ---------- | ------- | ----------------------------------------------------------------------------- |
| `amountIn` | uint256 | The amount required as the input for the swap in order to receive `amountOut` |

#### quoteExactOutput[​](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#quoteexactoutput) <a href="#quoteexactoutput" id="quoteexactoutput"></a>

```solidity
  function quoteExactOutput(
    bytes path,
    uint256 amountOut
  ) external returns (uint256 amountIn)
```

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

**Parameters:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#parameters-4)

| Name        | Type    | Description                                                 |
| ----------- | ------- | ----------------------------------------------------------- |
| `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:**[**​**](https://docs.uniswap.org/contracts/v3/reference/periphery/lens/Quoter#return-values-3)

| Name       | Type    | Description                                   |
| ---------- | ------- | --------------------------------------------- |
| `amountIn` | uint256 | The amount of first token required to be paid |
