IUniswapV3Factory
The Uniswap V3 Factory facilitates creation of Uniswap V3 pools and control over the protocol fees
#
Functions#
owner function owner( ) external view returns (address)
Returns the current owner of the factory
Can be changed by the current owner via setOwner
#
Return Values:Type | Description |
---|---|
address | address of the factory owner |
#
feeAmountTickSpacing function feeAmountTickSpacing( uint24 fee ) external view returns (int24)
Returns the tick spacing for a given fee amount, if enabled, or 0 if not enabled
A fee amount can never be removed, so this value should be hard coded or cached in the calling context
#
Parameters:Name | Type | Description |
---|---|---|
fee | uint24 | The enabled fee, denominated in hundredths of a bip. Returns 0 in case of unenabled fee |
#
Return Values:Type | Description |
---|---|
int24 | tick spacing |
#
getPool function getPool( address tokenA, address tokenB, uint24 fee ) external view returns (address pool)
Returns the pool address for a given pair of tokens and a fee, or address 0 if it does not exist
tokenA and tokenB may be passed in either token0/token1 or token1/token0 order
#
Parameters:Name | Type | Description |
---|---|---|
tokenA | address | The contract address of either token0 or token1 |
tokenB | address | The contract address of the other token |
fee | uint24 | The fee collected upon every swap in the pool, denominated in hundredths of a bip |
#
Return Values:Name | Type | Description |
---|---|---|
pool | address | The pool address |
#
createPool function createPool( address tokenA, address tokenB, uint24 fee ) external returns (address pool)
Creates a pool for the given two tokens and fee
tokenA and tokenB may be passed in either order: token0/token1 or token1/token0. tickSpacing is retrieved from the fee. The call will revert if the pool already exists, the fee is invalid, or the token arguments are invalid.
#
Parameters:Name | Type | Description |
---|---|---|
tokenA | address | One of the two tokens in the desired pool |
tokenB | address | The other of the two tokens in the desired pool |
fee | uint24 | The desired fee for the pool |
#
Return Values:Name | Type | Description |
---|---|---|
pool | address | The address of the newly created pool |
#
setOwner function setOwner( address _owner ) external
Updates the owner of the factory
Must be called by the current owner
#
Parameters:Name | Type | Description |
---|---|---|
_owner | address | The new owner of the factory |
#
enableFeeAmount function enableFeeAmount( uint24 fee, int24 tickSpacing ) external
Enables a fee amount with the given tickSpacing
Fee amounts may never be removed once enabled
#
Parameters:Name | Type | Description |
---|---|---|
fee | uint24 | The fee amount to enable, denominated in hundredths of a bip (i.e. 1e-6) |
tickSpacing | int24 | The spacing between ticks to be enforced for all pools created with the given fee amount |
#
Events#
OwnerChanged event OwnerChanged( address oldOwner, address newOwner )
Emitted when the owner of the factory is changed
#
Parameters:Name | Type | Description |
---|---|---|
oldOwner | address | The owner before the owner was changed |
newOwner | address | The owner after the owner was changed |
#
PoolCreated event PoolCreated( address token0, address token1, uint24 fee, int24 tickSpacing, address pool )
Emitted when a pool is created
#
Parameters:Name | Type | Description |
---|---|---|
token0 | address | The first token of the pool by address sort order |
token1 | address | The second token of the pool by address sort order |
fee | uint24 | The fee collected upon every swap in the pool, denominated in hundredths of a bip |
tickSpacing | int24 | The minimum number of ticks between initialized ticks |
pool | address | The address of the created pool |
#
FeeAmountEnabled event FeeAmountEnabled( uint24 fee, int24 tickSpacing )
Emitted when a new fee amount is enabled for pool creation via the factory
#
Parameters:Name | Type | Description |
---|---|---|
fee | uint24 | The enabled fee, denominated in hundredths of a bip |
tickSpacing | int24 | The minimum number of ticks between initialized ticks for pools created with the given fee |