πŸ¦„ πŸ¦„ πŸ¦„ Core smart contracts of Uniswap v3
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Go to file
Emily Williams d8b1c635c2
add bnb network (#628)
* add bnb network
7 months ago
.github feat: add stale config (#571) 1 year ago
audits Fix code style issues with Prettier (#629) 7 months ago
contracts Fix code style issues with Prettier (#629) 7 months ago
test Fix code style issues with Prettier (#629) 7 months ago
.gitattributes add prettier 4 years ago
.gitignore big test infra upgrade (hardhat + typechain) 3 years ago
.prettierrc add prettier 4 years ago
.solhint.json prettier + solhint 3 years ago
.yarnrc ignore scripts 3 years ago
LICENSE add LICENSE and make associated changes (#433) 3 years ago
README.md Dual license under GPL or BUSL (#557) 1 year ago
bug-bounty.md add tob audit 3 years ago
echidna.config.yml more robust price math testing + add incomplete pair echidna test (#98) 3 years ago
hardhat.config.ts add bnb network (#628) 7 months ago
package.json 1.0.1 2 years ago
tsconfig.json clean up the uniswap v3 factory test and add back the tsconfig.json 3 years ago
yarn.lock add network config for verifying arbitrum and optimism contracts 2 years ago

README.md

Uniswap V3

Lint Tests Fuzz Testing Mythx npm version

This repository contains the core smart contracts for the Uniswap V3 Protocol. For higher level contracts, see the uniswap-v3-periphery repository.

Bug bounty

This repository is subject to the Uniswap V3 bug bounty program, per the terms defined here.

Local deployment

In order to deploy this code to a local testnet, you should install the npm package @uniswap/v3-core and import the factory bytecode located at @uniswap/v3-core/artifacts/contracts/UniswapV3Factory.sol/UniswapV3Factory.json. For example:

import {
  abi as FACTORY_ABI,
  bytecode as FACTORY_BYTECODE,
} from '@uniswap/v3-core/artifacts/contracts/UniswapV3Factory.sol/UniswapV3Factory.json'

// deploy the bytecode

This will ensure that you are testing against the same bytecode that is deployed to mainnet and public testnets, and all Uniswap code will correctly interoperate with your local deployment.

Using solidity interfaces

The Uniswap v3 interfaces are available for import into solidity smart contracts via the npm artifact @uniswap/v3-core, e.g.:

import '@uniswap/v3-core/contracts/interfaces/IUniswapV3Pool.sol';

contract MyContract {
  IUniswapV3Pool pool;

  function doSomethingWithPool() {
    // pool.swap(...);
  }
}

Licensing

The primary license for Uniswap V3 Core is the Business Source License 1.1 (BUSL-1.1), see LICENSE. However, some files are dual licensed under GPL-2.0-or-later:

  • All files in contracts/interfaces/ may also be licensed under GPL-2.0-or-later (as indicated in their SPDX headers), see contracts/interfaces/LICENSE
  • Several files in contracts/libraries/ may also be licensed under GPL-2.0-or-later (as indicated in their SPDX headers), see contracts/libraries/LICENSE

Other Exceptions

  • contracts/libraries/FullMath.sol is licensed under MIT (as indicated in its SPDX header), see contracts/libraries/LICENSE_MIT
  • All files in contracts/test remain unlicensed (as indicated in their SPDX headers).