Lending and Flash Loans

Last Updated: 26th June 2023

You probably had to borrow money at one point in your life, e.g., for a student loan, a car loan, or a mortgage. Lending and borrowing are essential services in any financial system. Traditionally, lenders such as banks provide you with a loan in exchange for a fee in the form of an interest rate. Repaying the said loan is enforced by legal contracts with the bank.

Similar situations can be found on the blockchain as well. A borrower needs a sum of money immediately available for an operation, and a lender may agree to provide such a loan in exchange for a fee.

DeFi loans


DeFi lending allows users to become lenders or borrowers in a completely decentralized and permissionless way while maintaining full custody over their coins.

Users, who want to become lenders, supply their tokens to a particular money market and start receiving interest on their tokens according to the current supply APY (Annual Percentage Yield).

But how do you enforce the repayment of a loan on the blockchain?

Each loan on the blockchain needs to be collateralized with other tokens. In addition to that, as tokens are very volatile, blockchain loans are over-collateralized. For instance, if you want to borrow $1m in USDT, you need to provide $1.33m in XTZ as collateral.

You may then wonder, why would anyone take a loan if they need to provide even more as collateral?

There are multiple reasons:

  • They may not want to sell their original tokens.
  • They may want to avoid or delay paying capital gain taxes on their tokens.
  • They may want to use the borrowed funds to increase their leverage in a certain position.


For instance, Alice has 133 USDT and believes the price of XTZ will go down. Alice takes a loan of 20 XTZ using her 133 USDT (considering 5 USDT per XTZ, plus 33% for over-collateralization) to keep her XTZ coins. She immediately sells the 20 XTZ for 100 USDT. She now has 233 USDT (133 initially plus 100 from the sale) and owes a debt of 20 XTZ. Consider that XTZ goes down to $2. Alice buys 20 XTZ for 40 USDT, repays the 20 XTZ to the lender, and retrieves her 133 USDT collateral back. Alice now has $233 - 40 = 193$ USDT. She has made a $60 benefit. This whole operation is called a short position.


As long as the value of the collateral is superior or equal to 133% of the borrowed funds, there are no limits to how long a user can keep the borrowed funds.

However, if the value of the collateral falls below 133%, the user then has their collateral liquidated so the protocol can repay the borrowed amount.


Borrowers pay lenders interest on their loans, plus a platform fee. The interest rate is determined by supply and demand. For instance, if many lenders are offering loans for XTZ and demand is low, interest rates will be lowered to attract more demand. However, if there are few lenders but demand is high, interests are increased (lenders obviously want to earn as much money as possible). For instance, if traders believe the price of XTZ will go down, a lot of them might want to open short positions as seen in the example above, and therefore increase the demand for loans.

Interests paid on loans are based on their APY. Lenders usually offer two kinds of APY:

  • A variable APY, which is updated at every block depending on offer and demand.
  • A much higher but stable APY that will not change during the whole period of your loan.

Variable rates may sometimes be low and attractive but keep in mind that they can sharply move at any time. As seen above, if the exchange rate of XTZ goes down, demand for loans increases and variable APYs can skyrocket.

For instance, if you borrow $100 for a year at a stable APY of 10%, you will pay $10 interest. Now consider borrowing at a 5% variable APY, but after 6 months, the APY jumps to 30% for the rest of the year. You would then have to pay $2.5 interest for the first 6 months and $15 for the last 6 months.

Note that interests are computed at each block, increasing your debt a little every time. If APY jumps sharply, your debt might surpass the 133% collateral limit. You must close your loan or add more collateral, or your loan will be liquidated. This is how you can get liquidated based only on accrued interests even if the tokens borrowed and used as collateral hasn't changed in price (typically borrowing stablecoins with stablecoins).

Lending on Tezos

Yupana Finance: the first open-source and non-custodial lending protocol on Tezos

Mavryk Finance is available on Ghostnet and provides different financial services, including borrowing and lending.

Tezos Finance (aka "Tezfin") is currently in development and will soon enable the lending and borrowing of fungible Tezos crypto-assets including XTZ and Tezos-based tokens built with the FA token standards.

Flash loans

Flash loans have been popularized in 2020 and are very useful, they allow users to borrow tokens without any collateral. What's the catch?

A flash loan has to be borrowed and repaid within the same blockchain transaction.

To understand this concept, let's recall how transactions work on Tezos.


A transaction represents a set of steps that must be executed in an atomic way, i.e., either all the steps are executed, or the transaction is rolled back, and none of the steps take place.

Sending XTZ, sending FA2 tokens, and interacting with smart contracts can be steps executed within the scope of one transaction.

Transactions are grouped and included in a Tezos block. Each transaction can be observed on a block explorer such as tzStats.

On Tezos, transactions can consist of multiple consecutive steps, e.g., you could supply XTZ and borrow kUSD on Mavryk, swap half of your borrowed kUSD for USDT on Plenty and provide liquidity to the kUSD/USDT pool on Quipuswap - all in one single Tezos transaction. If any of these steps result in an error, the whole transaction would be rolled back, and none of the steps would occur. Note that you would still have to pay the gas fees. Even failed contract executions consume gas.

The gas cost bounds the number of steps in a single transaction. So although you could, in theory, create a valid transaction with thousands of steps, it'd be rejected because of the maximum limit on gas cost per block.

Remember that a flash loan has to be borrowed and repaid within the same transaction, so there is no risk that borrowers will not repay their borrowed amount.

Flash loan
FIGURE 1: Operation flow of a flash loan in the case of a successful repayment (green arrows) or failed repayment (red arrows)

Use cases

Here are three of the most common use cases for flash loans:


Arbitrage is the simultaneous purchase and sale of the same asset in different exchanges to profit from tiny differences in the asset's listed price. It exploits short-lived variations in the price of identical or similar financial instruments in other markets.

Flash loans are particularly interesting for arbitrageurs to increase profits. The picture below shows an arbitrage opportunity. Let's suppose that the price of USDT is currently 1 kUSD on Plenty but 0.99 kUSD on Quipuswap. An arbitrageur would exploit the difference as follows:

  • Step 1: Borrow 100,000 kUSD from Mavryk
  • Step 2: Exchange 100,000 kUSD against 101,010 USDT on Quipuswap
  • Step 3: Exchange 101,010 USDT against 101,010 kUSD on Plenty
  • Step 4: Repay the 100,000 kUSD on Mavryk (plus usually a 0.09% fee making the total repayment at 100,900 kUSD)
  • Step 5: Keep the remaining 110 kUSD in profits!

All these steps are included in one transaction. They either all succeed, or they will all fail.

FIGURE 2: A typical arbitrage operation involving a flash loan.

This process looks pretty easy, but keep in mind that arbitrageurs will still need to:

  • pay network fees, which can be pretty high in complex transactions.
  • take price slippage into account. (As seen in the DEX chapter, depending on the size of your order, marginal price and effective swap price can be quite different, leading to possible unprofitable outcomes).
  • face fierce competition. Arbitrage is a well-known practice, and many traders are doing it. On top of that, bots that monitor the mempool [4] can pick up your profitable arbitrage opportunity and send the same transaction with a higher gas fee, which would be inserted in a block sooner, basically stealing your arbitrage opportunity.

Collateral Swaps

Another application of flash loans is for collateral swaps. Let's say you have borrowed kUSD from Mavryk with XTZ as collateral. You can swap your collateral from XTZ to, for example, tzBTC in the following way:

  • Step 1: Take a flash loan in kUSD to cover the amount of kUSD that was borrowed
  • Step 2: Repay your Mavryk loan with borrowed kUSD
  • Step 3: Withdraw your XTZ
  • Step 4: Swap your XTZ for tzBTC on Plenty
  • Step 5: Supply tzBTC as collateral on Mavryk
  • Step 6: Borrow kUSD against your tzBTC collateral
  • Step 7: Repay flash loan with the borrowed kUSD + fee
  • Step 8: Congrats, you just swapped your collateral from XTZ to tzBTC and only paid 0.09% of the borrowed amount for this.


Finally, flash loans can also be used for self-liquidation. Let's say that you have a loan in kUSD on Mavryk with XTZ as collateral. The XTZ price keeps going down, and you're approaching the liquidation level. You also don't have or don't want to deposit more XTZ to decrease your liquidation level and you also don't have the kUSD required to repay the loan. Now, instead of allowing the contract to liquidate your collateral and charge you the liquidation fee, you can take the following steps:

  • Step 1: Take a flash loan for the amount of kUSD that you owe
  • Step 2: Repay your kUSD loan and withdraw your XTZ
  • Step 3: Swap enough XTZ to kUSD to repay the flash loan + fees
  • Step 4: Keep the rest of your XTZ


Flash loans are helpful building blocks in DeFi as they can be used for things like arbitrage, swapping collateral, and self-liquidation. Of course, the concept of flash loans is relatively new, and there are use cases still to be discovered in the future.

Lending and Flash loans on Tezos

Flash loans are not yet available on Tezos, but works are in progress.


Decentralized Autonomous Organization