This repository contains the core smart contracts for the Pendle Protocol.
Prominent DeFi protocols have introduced various yield bearing tokens, like Aave's aToken or Compound's cToken, which has shown incredible growth and community acceptance. Pendle Protocol builds on top of this layer, by splitting the yield bearing tokens into two tokens: the Yield Token (YT) that represents the right to receive the yield, and the Ownership Token (OT) that represents the right to the underlying yield bearing tokens. This allows for the trading of yield, which has wide-ranging applications.
On top of yield tokenisation, Pendle Protocol has an AMM specifically designed for the trading of time-decaying assets, which aims to minimise impermanent loss (IL) for liquidity providers.
- All current documentations for how Pendle works is at this link
- To deploy core contracts:
- set the multisig addresses in
.env
, similar to.env.example
- Please note that for networks other than
mainnet
andkovan
, the scripts will use the deploying key as all the multisig.
- Please note that for networks other than
- Run: (this runs
scripts/deploy/deploy.ts
)
yarn deploy:core --network <network>
- This will save the deployed contracts to
deployments/<network>.json
- If we want to reset the instance, put
RESET=true
:
RESET=true yarn deploy:core --network <network>
- set the multisig addresses in
- To deploy test instances of contracts (yield contracts, markets, liquidity mining) for an expiry: (this runs
scripts/manage/seed_test_contracts.ts
)EXPIRY=<expiry_to_seed> yarn deploy:seed --network <network>
- This will save the new yield contracts to
deployments/<network>.json
as well
- This will save the new yield contracts to
- To verify contracts that have been deployed in
deployments/<network>.json
:- First, install tenderly link
- Then,
tenderly login
- Run: (which runs
scripts/manage/verify_tenderly.ts
)
yarn verify --network <network>
- Create a .env file containing the following properties:
ALCHEMY_KEY=<insert your ALCHEMY_KEY key here>
- Run test:
yarn test
- Run test coverage:
yarn coverage:all
- In a separate terminal:
yarn hardhat node
- Mint tokens to alice, bob, charlie and let alice tokeniseYield, add liquidity and stake:
yarn dev
- Teleport by 1 week
yarn teleport
- In the contracts and tests, Yield Token (YT) are referred to as XYT. XYT and YT refer to the same thing.
The primary license for Pendle Core is the Business Source License 1.1 (BUSL-1.1), see LICENSE
.
- All files in
contracts/interfaces/
,contracts/governance/
andcontracts/mock
are licensed underMIT
(as indicated in their SPDX headers) contracts/periphery/Timelock.sol
andcontracts/tokens/PENDLE.sol
are also licensed underMIT
(as indicated in their SPDX header)- All files in
contracts/libraries/
are licensed underGPL-2.0-or-later
(as indicated in their SPDX headers), seecontracts/libraries/LICENSE