๐Ÿ”€Vault Router

The vault router contract is a convenient way to take flash loans from White Whale vaults. Instead of interacting with individual vaults, bots can request the vault router the desired asset to do the flash loan operation with and the router will take care of communicating and requesting the funds to the appropriate vault.

An interesting feature that the White Whale Vault Router is pioneering is the possibility to take multiple flash loans at once.

The code for the vault router can be found here.


The following are the messages that can be executed on the vault router:

Instantiate

Instantiates the vault router.

{
  "owner": "inj1...",
  "vault_factory_addr": "inj1..."
}
KeyTypeDescription

owner

String

The owner of the router

vault_factory_addr

String

The address for the vault factory

Migrate

Migrates the vault router.

{}

ExecuteMsg

Flashloan

Retrieves the desired assets and runs the msgs, paying the required amount back the vaults after running the messages, and returning the profit to the sender.

{
  "assets": [
    {
      "info": {
        "native_token": {
          "denom": "ujuno"
        }
      },
      "amount": "10000"
    }
  ],
  "msgs": [
    {
      "wasm": {
        "execute": {
          "contract_addr": "juno1...",
          "msg": "binary",
          "funds": []
        }
      }
    }
  ]
}
KeyTypeDescription

assets

Vec<Asset>

Desired assets for the flash loan(s)

msg

Vec<CosmosMsg>

Messages to be executed with the flash loan(s)

Next loan

Performs the next loan in case multiple flash loans are taken. This message is called internally by the vault where the flash loan is being taken from. Cannot be called manually.

{
  "next_loan": {
    "initiator": "juno1...",
    "payload": [
      {
        "wasm": {
          "execute": {
            "contract_addr": "juno1...",
            "msg": "binary",
            "funds": []
          }
        }
      }
    ],
    "to_loan": [
      [
        "juno1...",
        {
          "info":{
            "native_token":{
              "denom":"ujunox"
            }
          },
          "amount":"10000"
        }
      ]
    ],
    "loaned_assets": [
      [
        "juno1...",
        {
          "info":{
            "native_token":{
              "denom":"ujunox"
            }
          },
          "amount":"10000"
        }
      ]
    ]
  }
}
KeyTypeDescription

initiator

Addr

The address to pay back all profits to

source_vault

String

The vault contract that calls the `NextLoan message

payload

Vec<CosmosMsg>

The final message to run once all assets have been loaned

to_loan

Vec<(String, Asset)>

The next loans to run

loaned_assets

Vec<(String, Asset)>

The assets that have been loaned

Complete loan

Completes the flash-loan by paying back all outstanding loans, and returning profits to the sender. This message is called internally by the vault router, cannot be called manually.

{
  "complete_loan": {
    "initiator": "juno1...",
    "loaned_assets": [
      [
        "juno1...",
        {
          "info":{
            "native_token":{
              "denom":"ujunox"
            }
          },
          "amount":"10000"
        }
      ]
    ]
  }
}
KeyTypeDescription

initiator

Addr

The address to pay back all profits to

loaned_assets

Vec<(String, Asset)>

A vec of tuples where the first value represents the vault address, and the second value represents the loan size

Update config

Updates the configuration of the vault router.

{
   "update_config":{
      "owner":"juno1...",
      "vault_factory_addr":"juno1..."
   }
}
KeyTypeDescription

owner

Option<String>

New owner of the router

vault_factory_addr

Option<String>

New vault factory address

Queries

Retrieves the configuration of the vault router. Returns a Config struct.

Config

{
  "config": {}
}

Last updated