avocado.funddocs

Documentation

Everything you need to know about Avocado Fund — the decentralised USDC yield vault and identity-gated lending protocol on Arbitrum.

Arbitrum
ERC-4626 Vault
AVO Score
Persona KYC
On-chain Reputation
USDC
Non-custodial

Overview

Avocado Fund is a two-sided DeFi primitive. On one side, lenders deposit USDC into an ERC-4626 vault and receive yield generated from borrower interest. On the other, borrowers verified by Persona (government ID + selfie + sanctions screening) build an on-chain AVO Score (0–100) through repayment history — earning credit tiers from $25 to $10,000. Fully on-chain and non-custodial.

Earn Passive Yield

Deposit USDC and earn competitive APY as borrowers pay interest. Withdraw any time within available liquidity.

On-Chain Reputation

Persona KYC confirms a real human. AVO Score (0–100) grows with on-time repayments. All tracked transparently on the blockchain.

ERC-4626 Compatible

The vault follows the ERC-4626 tokenised vault standard, making it composable with the broader DeFi ecosystem.

Non-Custodial

Smart contracts hold all funds. The protocol team cannot move user assets. All code is open source.

How It Works

The system has two smart contracts: AvocadoVault (ERC-4626 deposit/yield) and AvocadoLending (credit lines). They work together so that lender capital flows to borrowers and interest flows back.

Lenders

deposit USDC

AvocadoVault

ERC-4626

AvocadoLending

credit lines

Borrowers

AVO Score verified

Interest paid by borrowers → distributed back to lenders as yield

1

Lenders supply USDC

Any wallet can deposit USDC into the AvocadoVault. The vault mints avUSDC shares proportional to the deposit. These shares appreciate over time as borrower interest accrues.

2

Capital is deployed to lending

The vault allocates USDC to the AvocadoLending contract. Utilisation is tracked on-chain and displayed in real-time. A cap of $5,000,000 limits total exposure.

3

Borrowers verify with Persona

Borrowers open the Borrow page, complete a Persona inquiry (government ID + selfie + sanctions check), and receive a credit limit tied to their verified identity.

4

Borrowers draw and repay USDC

Verified borrowers draw up to their credit limit. Interest accrues per second. Repayments reduce the principal and release the credit line for future use.

5

Lenders withdraw any time

Lenders burn their avUSDC shares to redeem USDC + accrued interest. Withdrawals are limited by available (non-deployed) liquidity.

The Vault (AvocadoVault)

The vault is a standard ERC-4626 tokenised vault. Depositors receive avUSDC shares that represent their proportional claim on all assets inside the vault — including interest earned.

AssetUSDC (6 decimals)
Share tokenavUSDC (ERC-20)
Vault cap$5,000,000 USDC
Performance fee10% of interest generated
ChainArbitrum (chainId 42161)
StandardERC-4626

Share price starts at 1.000000 and increases as interest accrues. Depositing 100 USDC when share price is 1.05 gives you ~95.24 avUSDC. Redeeming those shares later at 1.10 returns 104.76 USDC.

Key vault functions

deposit(assets, receiver)Deposit USDC, receive avUSDC shares
withdraw(assets, receiver, owner)Burn shares, receive USDC
redeem(shares, receiver, owner)Burn exact shares, receive USDC
convertToAssets(shares)Preview USDC value of shares
totalAssets()Total USDC owned by vault
sharePrice()Current price per avUSDC share × 1e6

Lending & Borrowing

The AvocadoLending contract manages credit lines for Persona-verified borrowers. Each verified human gets exactly one credit line — enforced off-chain via a PII-derived nullifier hash stored at verification time.

Up to $10,000 USDC

Credit limit

per verified human

12% APR fixed

Interest rate

accrues per second

None required

Collateral

Persona KYC is the collateral

Interest rate model

Avocado Fund uses a fixed 12% APR on all borrowings. Interest accrues per second on the outstanding principal. Lender yield from that 12% scales with vault utilisation — the more capital deployed, the higher the effective lender APY.

ParameterValue
Borrow APR12% fixed
Interest accrualPer second (continuous)
RepaymentAny time, no minimum
Lender APY (est.)~10.8% at full utilisation (after 10% fee)

Identity Verification (Persona)

Avocado Fund uses Persona for regulated identity verification. Each borrower completes a hosted inquiry that captures a government-issued ID, a liveness-checked selfie, and runs a sanctions / PEP / adverse media watchlist screen. Persona is the data controller for the raw documents — Avocado Fund receives only a cryptographic reference.

1

Open the verification flow

On the Borrow page, click "Verify your identity". The Persona widget opens inline; no redirect or separate app is required.

2

Capture ID + selfie

Upload a government-issued ID (passport, driver's licence, or national ID) and complete a short liveness-checked selfie. Persona extracts and authenticates the document.

3

Sanctions & PEP screen

Persona automatically runs the captured identity against global sanctions, PEP, and adverse media lists. A hit blocks approval.

4

Nullifier recorded

Once Persona delivers an `inquiry.approved` webhook, we derive two nullifiers: one per inquiry (replay / idempotency) and one from PII (sybil resistance across wallets). Both are stored locally against your wallet address.

5

Credit line activated

Verification unlocks borrowing immediately. Your credit limit is determined by your AVO Score on first use and grows as you repay.

Persona holds the raw ID document and selfie for its standard 7-year regulatory retention window. Avocado Fund stores only the inquiry id and a salted PII hash — no direct identifiers.

Yield & APY

All yield is real — it comes from borrower interest, not token inflation or subsidies. APY is variable and reflects real-time utilisation of the vault.

APY calculation

grossInterest = borrowedAssets × borrowAPR × (seconds / 31536000)

netInterest = grossInterest × (1 − performanceFeeBps / 10000)

lenderAPY = netInterest / totalAssets × 100

Interest accrues per second. The share price increases continuously as borrowers repay. There is no staking or claiming — your avUSDC shares automatically appreciate.

APY is variable. If utilisation drops (more repayments, fewer new borrows) the displayed APY will decrease. Historical APY charts are available on the Analytics page.

AVO Token

The AVO token is not yet live. At launch, only AvocadoVault (lend → avUSDC) and AvocadoLending (borrow) are deployed. All yield currently comes from real borrower interest paid into the vault.

AVO is the governance and incentive token of Avocado Fund. Total supply is capped at 1 billion tokens. Initial distribution covers team, advisors, treasury, and community incentives. Team and advisor allocations are locked in the on-chain TokenVesting contract with standard cliff + linear-vest schedules.

Token Vesting

Vesting schedules will be created on-chain at TGE. Until then, the TokenVesting contract address is a placeholder.

The TokenVesting contract holds team and advisor AVO allocations and releases them on a per-beneficiary cliff + linear vest schedule (founders: 12-month cliff, 24-month linear vest; advisors: 6-month cliff, 18-month linear vest). Beneficiaries call release() to claim whatever has vested at the current block time. Schedules marked as revocable can be revoked by the owner multisig (e.g. on a departure) — vested tokens still go to the beneficiary; unvested tokens return to the treasury.

For Lenders

Supply USDC to earn passive yield. No lock-up period, no liquidation risk. Your position is represented by avUSDC shares.

1

Connect your wallet

Connect an Arbitrum-compatible wallet (MetaMask, Coinbase Wallet, Rainbow, etc.) using the Connect Wallet button in the top navigation.

2

Get USDC on Arbitrum

Bridge USDC to Arbitrum using the Arbitrum Bridge or Coinbase. The vault accepts native USDC on Arbitrum.

3

Approve and deposit

Enter an amount on the Vault page → Supply tab. First-time depositors will need to approve the vault contract to spend USDC. The approval and deposit can happen in one flow.

4

Monitor your position

Your avUSDC balance and USDC value are shown in real-time on the Vault page. Analytics shows historical APY and vault health.

5

Withdraw any time

Switch to the Withdraw tab, enter an amount (up to your maxWithdraw), and confirm. You receive USDC + accrued interest immediately.

Withdrawals are limited by available liquidity (non-deployed assets). If utilisation is very high, some of your position may be temporarily illiquid until borrowers repay. The maxWithdraw value shown in the app reflects this in real time.

For Borrowers

Borrow USDC without collateral after a Persona identity check. Designed for real humans with real use cases — not bots or sybil attacks.

1

Prepare your documents

Have a government-issued ID ready (passport, driver's licence, or national ID). Persona supports document verification in 200+ countries.

2

Connect your wallet

Connect the wallet you want to receive USDC into. This wallet will be linked to your Persona inquiry — use a dedicated wallet for borrowing.

3

Verify on the Borrow page

Go to Borrow → Verify tab. The Persona inquiry opens inline; follow the prompts to capture your ID and a short selfie. Sanctions screening runs automatically.

4

Draw your credit line

Once verified, the Borrow tab activates. Enter an amount up to your credit limit and confirm. USDC is sent to your wallet immediately.

5

Repay to restore credit

Use the Repay tab to repay part or all of your balance. Full repayment restores your full credit limit for future use. Interest accrues per second until repaid.

Failing to repay may result in your wallet being flagged on-chain and your credit line suspended. Smart contract enforcement is automatic and irreversible.

Security

Non-custodial

All USDC is held by the smart contracts. The protocol deployer has no ability to withdraw user funds.

Open source contracts

All contract code is publicly available on GitHub. Verify every function yourself before interacting.

Vault cap

Deposits are capped at $5M to limit protocol exposure during early operation. The cap may increase post-audit.

Reentrancy protection

All state-mutating functions use OpenZeppelin's ReentrancyGuard to prevent reentrancy attacks.

Sybil resistance

PII-derived nullifier hashes (from Persona inquiry data) prevent the same human from opening multiple credit lines, even with multiple wallets.

Performance fee

A 10% performance fee on interest is the only revenue mechanism. There are no hidden fees or dilution.

Smart contracts have been audited by Omniscia — all 19 findings addressed and verified. Both contracts are live on Arbitrum One. The audit report will be published publicly. Only deposit amounts you are comfortable with. The vault cap limits total protocol exposure.

Frequently Asked Questions

Is Avocado Fund audited?

Yes. A formal external audit was completed by Omniscia — 19 findings (4 static + 15 manual), all remediated. 124 automated tests pass. Both contracts are live on Arbitrum One. The public report will be published shortly. Only deposit what you can afford to risk.

What chain is this on?

Avocado Fund is deployed on Arbitrum — an Ethereum L2 rollup. Gas fees are very low (typically under $0.01). You need ETH on Arbitrum for gas and USDC on Arbitrum to supply.

Can I lose money as a lender?

Yes — in theory. If borrowers default and the total bad debt exceeds available reserves, lender funds could be at risk. The vault cap, credit limits, and identity gating are all designed to minimise this risk. Lending to uncollateralised borrowers always carries some credit risk.

Why does my maxWithdraw show less than my balance?

Your maxWithdraw is capped by available (non-deployed) liquidity. If the vault is highly utilised, some of your balance is lent out. As borrowers repay, your withdrawable amount increases. Check the utilisation rate on the Analytics page.

How does Persona verification work technically?

Persona opens an embedded inquiry widget that captures a government-issued ID, a liveness-checked selfie, and runs a watchlist / PEP / adverse-media screen. When the inquiry is approved, Persona sends an HMAC-signed webhook to our server. The server re-fetches the authoritative inquiry from the Persona REST API, derives a salted PII hash (for cross-wallet sybil defence), and records both the inquiry nullifier and the PII nullifier locally against your wallet.

Can I have multiple credit lines with different wallets?

No. A PII-derived nullifier hash (salted, one-way) is computed from your Persona inquiry and stored in a dedicated namespace. Attempting to verify with the same real identity on a different wallet collides on that hash and is rejected.

What happens if I don't repay my loan?

Interest continues to accrue, increasing your debt. If your outstanding debt exceeds your credit limit, the contract may suspend your ability to draw further. On-chain bad debt affects the overall vault and can reduce lender yield.

What is the performance fee and where does it go?

10% of all interest earned is taken as a performance fee, sent to the protocol treasury address at the time interest is collected. The remaining 90% accrues to lenders via share price appreciation.

Is there a token?

Yes — AVO is the native token (ERC-20, 1B max supply cap). Team and advisor allocations are locked in the on-chain TokenVesting contract (cliff + linear vest). At launch, AVO is not yet live; it will be activated in a future update. avUSDC is a separate yield-bearing receipt token representing your vault deposit. All vault yield is sourced from real borrower interest.

How do I get support?

Open an issue on GitHub or reach out via the community channels linked in the footer. For security disclosures, please use responsible disclosure by emailing the security contact in the repository.

🥑

Ready to start?

Supply USDC to earn yield, or verify your identity with Persona to access a credit line.