irys.fund(amount)
Funds the Irys network (opens in a new tab) you connected to with the specified number of tokens.
For more information on how funding and withdrawing are handled, see our docs (opens in a new tab).
Parameters
amount
: The amount to fund (in atomic units)multiplier
: Fee multiplier (optional)
Returns
response
: A JSON object with the following values
response = {
id, // The transaction id of the fund transfer
quantity, // How much is being transferred
reward, // The amount taken by the network as a fee
target, // The address the funds were sent to
};
Upfront funding
You can up-front fund a node, where you send over enough funds to cover all of a project’s uploads. When upfront funding, you may want to [write a script to monitor your stored balance, topping up when needed.](https://github.com/Irys-xyz/Irys-docs/blob/352323abeb1d6e64bbb1cdbb7d0e6fd55363d1d4/pages/hands-on/tutorials/monitor-node-balance.mdx#L9 (opens in a new tab)
try {
const irys = await getIrys();
const fundTx = await irys.fund(irys.utils.toAtomic(0.05));
console.log(`Successfully funded ${irys.utils.fromAtomic(fundTx.quantity)} ${irys.token}`);
} catch (e) {
console.log("Error funding node ", e);
}
Lazy-funding
You can also lazy-fund a node where you check the cost to upload each file first and then transfer exact funds. This works best with currencies like MATIC, ETH and SOL whose balances post (almost) instantly.
try {
const irys = await getIrys();
const pathToFile = "./myNFT.png";
const { size } = await fs.promises.stat(pathToFile);
const price = await irys.getPrice(size);
await irys.fund(price);
const { id } = await irys.uploadFile(pathToFile);
console.log(`${pathToFile} --> Uploaded to https://gateway.irys.xyz/${id}`);
} catch (e) {
console.log("Error funding node ", e);
}
Not all calls to irys.fund()
will post immediately to your account, some blockchains are faster than others. When funding with AR, it can take upwards of 40 minutes before the balance post. For MATIC, ETH and SOL, balances will usually post in < 10s.
Fee multiplier
The multiplier
parameter multiplies the fees we allow the network to take, in effect prioritizing the transaction. Normally you can safely ignore this parameter, however, if you're experiencing errors when funding, you can try passing a value of 1.2
or more.
try {
const irys = await getIrys();
const fundTx = await irys.fund(irys.utils.toAtomic(0.05), 1.2);
console.log(`Successfully funded ${irys.utils.fromAtomic(fundTx.quantity)} ${irys.token}`);
} catch (e) {
console.log("Error funding node ", e);
}
Paid RPCs
When transferring tokens (opens in a new tab) we use public RPCs. Sometimes these can be slow to confirm transactions. If you're experiencing an error when funding, consider using a paid RPC.
const network = "devnet;
const providerUrl = ""; // Paid RPC URL
const token = "ethereum";
const privateKey = process.env.PRIVATE_KEY;
const irys = new Irys({
network, // URL of the node you want to connect to
token, // Currency used for payment
key: privateKey, // ETH or SOL private key
config: { providerUrl },
});