flashloan-rs • ci license solidity Crates.io

Minimal flashloan borrower contracts with an extensible rust sdk.

Getting Started

Flashloan-rs is published to crates.io as flashloan-rs.

To use the crate in a Rust project, run the cargo add command like so: cargo add flashloan-rs.

Or, add the following to your Cargo.toml:

toml [dependencies] flashloan-rs = "0.2.3"

Usage

Flashloan-rs is built to be extremely simple to use.

Quick Construction

```rust,ignore use std::{str::FromStr, sync::Arc}; use flashloan_rs::prelude::; use ethers::prelude::;

// Create a web3 provider let client = Provider::::tryfrom("https://eth-mainnet.g.alchemy.com/v2/your-api-key").unwrap(); let arcclient = Arc::new(client);

// Config let walletaddress = Address::fromstr("YOURADDRESS").unwrap(); let lender = Address::fromstr("LENDERADDRESS").unwrap(); let tokentoflashloan = Address::fromstr("TOKENADDRESSTOFLASHLOAN").unwrap(); let amounttoflashloan = U256::fromdec_str("1000000000000000000").unwrap();

// Create a flashloan builder // Alternatively, these parameters can be set using the builder pattern (see the next example) let mut builder = FlashloanBuilder::new( Arc::clone(&arcclient), // web3 provider 1, // chain id Some(walletaddress), // wallet public address Some(lender), // address of the EIP-3156 Compliant Flash Lender Some(tokentoflashloan), // token address to flashloan Some(amounttoflashloan), // amount to flashloan None, // override the flash borrower contract );

// Deploy the flashloan borrower contract builder.deploy(None, None).await.unwrap();

// Execute the flashloan and grab the transaction receipt let optionaltxreceipt = builder.execute().await.unwrap(); let txreceipt = optionaltx_receipt.unwrap(); ```

Builder Pattern

```rust,ignore use std::{str::FromStr, sync::Arc}; use flashloan_rs::prelude::; use ethers::prelude::;

// Create a web3 provider let client = Provider::::tryfrom("https://eth-mainnet.g.alchemy.com/v2/your-api-key").unwrap(); let arcclient = Arc::new(client);

// Config let walletaddress = Address::fromstr("YOURADDRESS").unwrap(); let lender = Address::fromstr("LENDERADDRESS").unwrap(); let tokentoflashloan = Address::fromstr("TOKENADDRESSTOFLASHLOAN").unwrap(); let amounttoflashloan = U256::fromdec_str("1000000000000000000").unwrap();

// Create a flashloan builder let mut builder = FlashloanBuilder::new(arc_client, 1, None, None, None, None, None);

// Set values using the builder pattern builder.withowner(walletaddress).withlender(lender).withtoken(tokentoflashloan).withamount(amountto_flashloan);

// ... ```

Blueprint

txt flashloan-rs ├─ contracts │ ├─ interfaces │ │ ├─ IERC20.sol — ERC20 interface │ │ ├─ IERC3156FlashBorrower.sol — Flashloan borrower interface | | └─ IERC3156FlashLender.sol — Flashloan lender interface │ ├─ FlashBorrower.huff — A https://github.com/huff-language Flashloan Receiver Contract Implementation │ └─ FlashBorrower.sol — An Extensible Flashloan Receiver Contract ├─ examples │ ├─ custom_borrower.rs — Flashloan-rs usage with a custom borrower contract │ └─ pure_arb.rs — Executing a pure arbitrage with flashloan-rs ├─ lib — Foundry Libraries ├─ src │ ├─ builder.rs — The primary rust FlashloanBuilder library │ ├─ contract.rs — Abi Generated FlashBorrower Contract │ ├─ errors.rs — Custom errors for flashloan-rs │ └─ lib.rs — Module Exports ├─ tests │ ├─ contracts │ │ └─ FlashBorrower.t.sol — FlashBorrower.sol test suite │ └─ crate | └─ builder.rs — Unit tests for flashloan-rs ├─ foundry.toml — Foundry Config └─ Cargo.toml — The flashloan-rs Cargo Manifest

License

MIT

Acknowledgements

A few very notable repositories that were used as reference: