Integrate Embedded Wallets with the Avalanche Blockchain in Unity
While using the Embedded Wallets Unity SDK (formerly Web3Auth), you get the private key within the user scope. Use it with Nethereum to make EVM-based blockchain calls on Avalanche (C-Chain): get account, fetch balance, sign and send transactions, and interact with contracts.
The SDKs are now branded as MetaMask Embedded Wallet SDKs (formerly Web3Auth Plug and Play SDKs). Package names and APIs remain Web3Auth (for example, Web3Auth React SDK), and code snippets may reference web3auth identifiers.
Chain Details for Avalanche
- Mainnet
- Testnet
- Chain ID: 0xa86a
- Public RPC URL: https://api.avax.network/ext/bc/C/rpc (Avoid using public rpcTarget in production, use services like Infura)
- Display Name: Avalanche C-Chain
- Block Explorer Link: https://snowtrace.io
- Ticker: AVAX
- Ticker Name: Avalanche
- Chain ID: 0xa869
- Public RPC URL: https://api.avax-test.network/ext/bc/C/rpc (Avoid using public rpcTarget in production, use services like Infura)
- Display Name: Avalanche Fuji Testnet
- Block Explorer Link: https://testnet.snowtrace.io
- Ticker: AVAX
- Ticker Name: Avalanche
Installation
In this reference, we're using the Nethereum library to demonstrate how to make blockchain calls
using it with Web3Auth.
Package installation instructions (Official repository)
Install via Package Manager using OpenUpm
- 
open Edit/Project Settings/Package Manager 
- 
add a new Scoped Registry (or edit the existing OpenUPM entry) - 
Name package.openupm.com 
- 
Scope(s) com.nethereum.unity 
 
- 
- 
click Save or Apply 
- 
Open Window/Package Manager 
- 
click + 
- 
select Add package by name... or Add package from git URL... 
- 
paste com.nethereum.unity into name 
- 
paste 4.19.2 into version (or your preferred one) 
- 
click Add 
Installing package for old version
- 
Download the latest net461dllsAOT.zippackage from Nethereum's latest release
- 
Extract and the rename the folder to NethereumLibfor easy identification.
- 
Move the folder to the Assets/Pluginsfolder of your Unity project.
- 
You might have to delete a few files from the NethereumLibfolder, if you're getting any errors while building the project. For our implementation, we deleted the following files:Newtonsoft.Json.dll, all the files starting withSystem.*,UnityEngine.dll,Nethereum.Web3Lite.dll,Nethereum.HdWallet.dll,NBitcoin.dll,Nethereum.RPC.Reactive.dllandCommon.Logging.Core.dll.
We have followed this guide to set up
the Nethereum package in our app. You can check their sample applications as well for a decent
reference.
You can also check the Web3Auth Unity Sample Apps, where we have added the required packages.
Initialize
using Nethereum.Web3;
using Nethereum.Util;
using Nethereum.Signer;
using Nethereum.Hex.HexConvertors.Extensions;
using Nethereum.ABI.Encoders;
using Nethereum.Hex.HexTypes;
using Nethereum.Web3.Accounts;
using Nethereum.Web3.Accounts.Managed;
public class Web3AuthScript : MonoBehaviour
{
    Web3 web3;
    Web3Auth web3Auth;
    private string privateKey;
    private Account account;
    const string rpcURL = "" // EVM chain RPC URL
    void Start()
    {
      web3Auth = GetComponent<Web3Auth>();
      // Add Web3Auth Unity SDK Initialisation Code here
      web3Auth.onLogin += onLogin;
      web3Auth.onLogout += onLogout;
      web3 = new Web3(rpcURL);
    }
    private void onLogin(Web3AuthResponse response)
    {
        privateKey = response.privKey;
        var newAccount = new Account(privateKey);
        account = newAccount;
    }
// ...
}
Get User Info
You get the user information after a successful login returned from the login method. The userInfo object contains the user information, whereas
the privKey object contains the private key that can be used to make blockchain calls.
private string userInfo;
private void onLogin(Web3AuthResponse response)
{
  userInfo = JsonConvert.SerializeObject(response.userInfo, Formatting.Indented);
}
Get Account
In this reference, we're using the Nethereum library to demonstrate how to make blockchain calls
using it with Web3Auth.
Package installation instructions (Official repository)
Install via Package Manager using OpenUpm
- 
open Edit/Project Settings/Package Manager 
- 
add a new Scoped Registry (or edit the existing OpenUPM entry) - 
Name package.openupm.com 
- 
Scope(s) com.nethereum.unity 
 
- 
- 
click Save or Apply 
- 
Open Window/Package Manager 
- 
click + 
- 
select Add package by name... or Add package from git URL... 
- 
paste com.nethereum.unity into name 
- 
paste 4.19.2 into version (or your preferred one) 
- 
click Add 
Installing package for old version
- 
Download the latest net461dllsAOT.zippackage from Nethereum's latest release
- 
Extract and the rename the folder to NethereumLibfor easy identification.
- 
Move the folder to the Assets/Pluginsfolder of your Unity project.
- 
You might have to delete a few files from the NethereumLibfold er, if you're getting any errors while building the project. For our implementation, we deleted the following files:Newtonsoft.Json.dll, all the files starting withSystem.*,UnityEngine.dll,Nethereum.Web3Lite.dll,Nethereum.HdWallet.dll,NBitcoin.dll,Nethereum.RPC.Reactive.dllandCommon.Logging.Core.dll.
We have followed this guide to set up
the Nethereum package in our app. You can check their sample applications as well for a decent
reference.
You can also check the Web3Auth Unity Sample Apps, where we have added the required packages.
Get Balance
public void getBalance() {
  if (account == null) {
    Debug.Log("Please Login First");
    return;
  }
  var balance = web3.Eth.GetBalance.SendRequestAsync(account.Address).Result.Value;
  Debug.Log(balance);
}
Sign a message
public void signMessage() {
  if (account == null) {
    Debug.Log("Please Login First");
    return;
  }
  var msg = "test message 19/01/2023 02:55PM";
  var signer = new EthereumMessageSigner();
  var signature = signer.EncodeUTF8AndSign(msg, new EthECKey(privateKey));
  Debug.Log(signature);
}
Send Transaction
public async void sendTransaction() {
  if (account == null) {
    Debug.Log("Please Login First");
    return;
  }
  var toAddress = "0x2E464..82D5057fB507Cc21";
  var transaction = await web3.TransactionManager.SendTransactionAsync(account.Address, toAddress, new Nethereum.Hex.HexTypes.HexBigInteger(1));
  Debug.Log(transaction);
}