# Home

```
,-. .---.  .-. .-.  ,---.  ,---.    .---.  _______  .---.    ,--,  .---.  ,-.
|(|/ .-. ) |  \| |  | .-.\ | .-.\  / .-. )|__   __|/ .-. ) .' .') / .-. ) | |
(_)| | |(_)|   | |  | |-' )| `-'/  | | |(_) )| |   | | |(_)|  |(_)| | |(_)| |
| || | | | | |\  |  | |--' |   (   | | | | (_) |   | | | | \  \   | | | | | |
| |\ `-' / | | |)|  | |    | |\ \  \ `-' /   | |   \ `-' /  \  `-.\ `-' / | `--.
`-' )---'  /(  (_)  /(     |_| \)\  )---'    `-'    )---'    \____\)---'  |( __.'
   (_)    (__)     (__)        (__)(_)             (_)            (_)     (_)
```

### [Ion Protocol](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#ion-protocol" id="ion-protocol"></a>

Ion Protocol is a decentralized money market purpose-built for all types of staked and restaked assets. Ion protocol unlocks capital efficiency for yield-bearing staking collaterals using reactive interest rates, collateral-specific utilization, and price-agnostic liquidations. Borrowers can collateralize their yield-bearing staking assets to borrow WETH, and lenders can gain exposure to the boosted staking yield generated by borrower collateral.

### [Documentation](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#documentation" id="documentation"></a>

To learn more about Ion Protocol without code, please visit:

* [Our website](https://ionprotocol.io/)
* [User Docs](https://docs.ionprotocol.io/)

To learn more about the protocol's technical details, please visit:

* [Audit Docs for Security Researchers](https://ionprotocol.notion.site/Ion-Protocol-Audit-Docs-c871ff178bf54447bd28018cd5a88f75?pvs=74)

### [Audits](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#audits" id="audits"></a>

> Please report any white hat findings for potential vulnerabilities to <security@molecularlabs.io>

* OpenZeppelin Audit December 2023
  * [Open Zepplin Audit Report](https://blog.openzeppelin.com/ion-protocol-audit)
* [Hats Finance January 2024](https://app.hats.finance/audit-competitions)
  * Regular Audit and Formal Verification Competition with Certora
  * \[Competition Completed]

To engage in conversations around Ion Protocol and the staking/restaking ecosystem, please join the [Discord](https://t.co/6np4WvIx70) channel or follow [@ionprotocol](https://twitter.com/ionprotocol) on X.

### [Usage](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#usage" id="usage"></a>

#### [Installing Dependencies](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#installing-dependencies" id="installing-dependencies"></a>

Install Bun

```
curl -fsSL https://bun.sh/install | bash
```

Run Bun install for javascript dependencies

```
bun install
```

Install jq

```
brew install jq
```

#### [Environmental Variables](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#environmental-variables" id="environmental-variables"></a>

Copy .env.example to .env and add environmental variables.

```
MAINNET_RPC_URL=https://mainnet.infura.io/v3/
MAINNET_ARCHIVE_RPC_URL= # Archive node used for creating fork environments
MAINNET_ETHERSCAN_URL=https://api.etherscan.io/api
ETHERSCAN_API_KEY=
RPC_URL= # RPC of the desired testnet used in deployment scripts
```

#### [Test](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#test" id="test"></a>

1. The test suite includes fork tests that require foundry ffi.
2. Add RPC\_URLs to the .env and run forge test with the --ffi flag.

```
forge test --ffi
```

#### [Testnet Setup](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#testnet-setup" id="testnet-setup"></a>

1. Set up anvil as a mainnet fork.

   * For the contracts using mainnet contract addresses as constants to work properly, the testnet needs to be a fork of a mainnet environment.

   ```
   anvil --fork-url $MAINNET_ARCHIVE_RPC_URL --chain-id 31337
   ```
2. Set anvil as the target RPC for the deployment script in `.env`

   ```
   # ...other environmental variables
   RPC_URL=http://localhost:8545

   ```
3. Run the testnet deployment script

   ```
   bash node.sh
   ```
4. Run the foundry script to verify that the contracts are working properly.

   ```
   forge script script/__TestFlashLeverage.s.sol --rpc-url $RPC_URL
   ```

#### [Format](broken://pages/mNviLao2U37WZ9kMMbiB) <a href="#format" id="format"></a>

```
$ forge fmt
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.ionprotocol.io/devs/smart-contract-architecture/home.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
