DEX with 1 inch not executing the trade, but does connect to metamask

Hi, i am quite new to programming. thanks for all the tutorials online, its really amazing that you guys put the backend together like this. its been taking me some time to soak in and understand but I have a large app and my team is having difficulty doing the b/c integration so i wanted to learn it myself. I want to understand first how it works. I used filip’s DEX tutorial with bsc instead of eth. it connects to my metamask, and even does the communicating of the contract executed on bsc (paid small gas fee), but it gives me a “Swap complete” prompt on 2nd click of swap, even though no execution of trading tokens was made. I am in the US, but using a vpm. so im pretty sure 1inch doesnt support US customers, but my VPN is up. I looked into Mihcal’s error with bsc to add the await that Dani suggested, but I wasnt sure if it was the same problem since his code is written differently.

could it be because of the chrome im using? i am able to connect to pancake swap. here is the code below:

Also, how do you change the url to your own wesbite?

is using a .crypto domain (instead of .com) similar process?

main.js

/** Connect to Moralis server */

const serverUrl = "https://................r";

const appId = "BaAH........................";

Moralis.start({ serverUrl, appId });

let currentTrade = {};

let currentSelectSide;

let tokens;

async function init() {

  await Moralis.start({ serverUrl, appId });

  await Moralis.enableWeb3();

  await listAvailableTokens();

  currentUser = Moralis.User.current();

  if (currentUser) {

    document.getElementById("swap_button").disabled = false;

  }

}

async function listAvailableTokens() {

  const result = await Moralis.Plugins.oneInch.getSupportedTokens({

    chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)

  });

  tokens = result.tokens;

  let parent = document.getElementById("token_list");

  for (const address in tokens) {

    let token = tokens[address];

    let div = document.createElement("div");

    div.setAttribute("data-address", address);

    div.className = "token_row";

    let html = `

        <img class="token_list_img" src="${token.logoURI}">

        <span class="token_list_text">${token.symbol}</span>

        `;

    div.innerHTML = html;

    div.onclick = () => {

      selectToken(address);

    };

    parent.appendChild(div);

  }

}

function selectToken(address) {

  closeModal();

  console.log(tokens);

  currentTrade[currentSelectSide] = tokens[address];

  console.log(currentTrade);

  renderInterface();

  getQuote();

}

function renderInterface() {

  if (currentTrade.from) {

    document.getElementById("from_token_img").src = currentTrade.from.logoURI;

    document.getElementById("from_token_text").innerHTML = currentTrade.from.symbol;

  }

  if (currentTrade.to) {

    document.getElementById("to_token_img").src = currentTrade.to.logoURI;

    document.getElementById("to_token_text").innerHTML = currentTrade.to.symbol;

  }

}

async function login() {

  try {

    currentUser = Moralis.User.current();

    if (!currentUser) {

      currentUser = await Moralis.authenticate();

    }

    document.getElementById("swap_button").disabled = false;

  } catch (error) {

    console.log(error);

  }

}

function openModal(side) {

  currentSelectSide = side;

  document.getElementById("token_modal").style.display = "block";

}

function closeModal() {

  document.getElementById("token_modal").style.display = "none";

}

async function getQuote() {

  if (!currentTrade.from || !currentTrade.to || !document.getElementById("from_amount").value) return;

  let amount = Number(document.getElementById("from_amount").value * 10 ** currentTrade.from.decimals);

  const quote = await Moralis.Plugins.oneInch.quote({

    chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)

    fromTokenAddress: currentTrade.from.address, // The token you want to swap

    toTokenAddress: currentTrade.to.address, // The token you want to receive

    amount: amount,

  });

  console.log(quote);

  document.getElementById("gas_estimate").innerHTML = quote.estimatedGas;

  document.getElementById("to_amount").value = quote.toTokenAmount / 10 ** quote.toToken.decimals;

}

async function trySwap() {

  let address = Moralis.User.current().get("ethAddress");

  let amount = Number(document.getElementById("from_amount").value * 10 ** currentTrade.from.decimals);

  if (currentTrade.from.symbol !== "ETH") {

    const allowance = await Moralis.Plugins.oneInch.hasAllowance({

      chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)

      fromTokenAddress: currentTrade.from.address, // The token you want to swap

      fromAddress: address, // Your wallet address

      amount: amount,

    });

    console.log(allowance);

    if (!allowance) {

      await Moralis.Plugins.oneInch.approve({

        chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)

        tokenAddress: currentTrade.from.address, // The token you want to swap

        fromAddress: address, // Your wallet address

      });

    }

  }

  try {

    let receipt = await doSwap(address, amount);

    alert("Swap Complete");

  } catch (error) {

    console.log(error);

  }

}

function doSwap(userAddress, amount) {

  return Moralis.Plugins.oneInch.swap({

    chain: "eth", // The blockchain you want to use (eth/bsc/polygon)

    fromTokenAddress: currentTrade.from.address, // The token you want to swap

    toTokenAddress: currentTrade.to.address, // The token you want to receive

    amount: amount,

    fromAddress: userAddress, // Your wallet address

    slippage: 1,

  });

}

init();

document.getElementById("modal_close").onclick = closeModal;

document.getElementById("from_token_select").onclick = () => {

  openModal("from");

};

document.getElementById("to_token_select").onclick = () => {

  openModal("to");

};

document.getElementById("login_button").onclick = login;

document.getElementById("from_amount").onblur = getQuote;

document.getElementById("swap_button").onclick = trySwap;
<!DOCTYPE html>

<html>

  <head>

      <meta charset="utf-8">

      <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <title>Dex Cross function v1 SG</title>

    <script src="https://cdn.jsdelivr.net/npm/web3@latest/dist/web3.min.js"></script>

    <script src="https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4=" crossorigin="anonymous"></script>

    <script src="https://unpkg.com/moralis/dist/moralis.js"></script>

    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>

    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">

    <link rel="stylesheet" href="./style.css">

  </head>

  <body>

    <nav class="navbar navbar-expand-lg navbar-light bg-light">

        <a class="navbar-brand" href="#">Decentralized DEX SG</a>

        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">

          <span class="navbar-toggler-icon"></span>

        </button>

     

        <div class="collapse navbar-collapse" id="navbarSupportedContent">

          <ul class="navbar-nav mr-auto">

            <li class="nav-item active">

              <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>

            </li>

          </ul>

          <button id="login_button" class="btn btn-outline-primary my-2 my-sm-0" type="submit">Sign in with Metamask</button>

      </div>

    </nav>

  <div class="container">

      <div class="row">

          <div class="col col-md-6 offset-md-3" id="window">

              <h4>Swap</h4>

              <div id="form">

                  <div class="swapbox">

                      <div class="swapbox_select token_select" id="from_token_select">

                          <img class="token_image" id="from_token_img">

                          <span id="from_token_text"></span>

                      </div>

                      <div class="swapbox_select">

                          <input class="number form-control" placeholder="amount" id="from_amount">

                      </div>

                  </div>

                  <div class="swapbox">

                      <div class="swapbox_select token_select"  id="to_token_select">

                          <img class="token_image" id="to_token_img">

                          <span id="to_token_text"></span>

                      </div>

                      <div class="swapbox_select">

                          <input class="number form-control" placeholder="amount" id="to_amount">

                      </div>

                  </div>

                  <div>Estimated Gas: <span id="gas_estimate"></span></div>

                  <button disabled class="btn btn-large btn-primary btn-block" id="swap_button">

                      Swap

                  </button>

              </div>

          </div>

      </div>

  </div>

  <div class="modal" id="token_modal" tabindex="-1" role="dialog">

      <div class="modal-dialog" role="document">

        <div class="modal-content">

          <div class="modal-header">

            <h5 class="modal-title">Select token</h5>

            <button id="modal_close" type="button" class="close" data-dismiss="modal" aria-label="Close">

              <span aria-hidden="true">&times;</span>

            </button>

          </div>

          <div class="modal-body">

            <div id="token_list"></div>

          </div>

        </div>

      </div>

    </div>

  <script type="text/javascript" src="./main.js"></script>

</body>

style.css

#window{

    margin-top: 50px;

    background-color: #000;

    color: #fff;

    padding: 15px;

    border-radius: 20px;

    box-shadow: 0 0 5px black;

}

.Swapbox_select {

    width: 50%;

    float: left;

}

.Swapbox{

    overflow: auto;

    margin: 20px 0;

    padding: 20px;

    background-color: #2f2f2f;

    border-radius: 20px;

    border: 1px solid #c00d99;

}

.token_select{

    padding:5px 0;

}

.token_select:hover{

    background-color: #464646;

    cursor: pointer;

   

}

.token_list_img, .token_image{

    width: 40px;

}

.modal-body{

    height: 600px;

    overflow: scroll;

}

.token_row{

    padding: 5px 10px;

}

.token_row:hover{

    background-color: #e4e4e4;

    cursor: pointer;

}

Hello @emperorshaq

In order to help you I need the payload that you are sending to the plugin.

Thanks

i tried looking into it before messaging you back, but how do i obtain a payload to the plugin?

Hey @emperorshaq

I need to know the object that you are passing as parameter to the plugin.
By having that object, I will be able to verify if there is an issue, or if the params you are providing to the plugin are somehow invalid.

/** Connect to Moralis server */
const serverUrl = "https://server";
const appId = "BaZm";
Moralis.start({ serverUrl, appId });


let currentTrade = {};
let currentSelectSide;
let tokens;

async function init() {
  await Moralis.start({ serverUrl, appId });
  await Moralis.enableWeb3();
  await listAvailableTokens();
  currentUser = Moralis.User.current();
  if (currentUser) {
    document.getElementById("swap_button").disabled = false;
  }
}

async function listAvailableTokens() {
  const result = await Moralis.Plugins.oneInch.getSupportedTokens({
    chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)
  });
  tokens = result.tokens;
  let parent = document.getElementById("token_list");
  for (const address in tokens) {
    let token = tokens[address];
    let div = document.createElement("div");
    div.setAttribute("data-address", address);
    div.className = "token_row";
    let html = `
        <img class="token_list_img" src="${token.logoURI}">
        <span class="token_list_text">${token.symbol}</span>
        `;
    div.innerHTML = html;
    div.onclick = () => {
      selectToken(address);
    };
    parent.appendChild(div);
  }
}

function selectToken(address) {
  closeModal();
  console.log(tokens);
  currentTrade[currentSelectSide] = tokens[address];
  console.log(currentTrade);
  renderInterface();
  getQuote();
}

function renderInterface() {
  if (currentTrade.from) {
    document.getElementById("from_token_img").src = currentTrade.from.logoURI;
    document.getElementById("from_token_text").innerHTML = currentTrade.from.symbol;
  }
  if (currentTrade.to) {
    document.getElementById("to_token_img").src = currentTrade.to.logoURI;
    document.getElementById("to_token_text").innerHTML = currentTrade.to.symbol;
  }
}

async function login() {
  try {
    currentUser = Moralis.User.current();
    if (!currentUser) {
      currentUser = await Moralis.authenticate();
    }
    document.getElementById("swap_button").disabled = false;
  } catch (error) {
    console.log(error);
  }
}

function openModal(side) {
  currentSelectSide = side;
  document.getElementById("token_modal").style.display = "block";
}
function closeModal() {
  document.getElementById("token_modal").style.display = "none";
}

async function getQuote() {
  if (!currentTrade.from || !currentTrade.to || !document.getElementById("from_amount").value) return;

  let amount = Number(document.getElementById("from_amount").value * 10 ** currentTrade.from.decimals);

  const quote = await Moralis.Plugins.oneInch.quote({
    chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)
    fromTokenAddress: currentTrade.from.address, // The token you want to swap
    toTokenAddress: currentTrade.to.address, // The token you want to receive
    amount: amount,
  });
  console.log(quote);
  document.getElementById("gas_estimate").innerHTML = quote.estimatedGas;
  document.getElementById("to_amount").value = quote.toTokenAmount / 10 ** quote.toToken.decimals;
}

async function trySwap() {
  let address = Moralis.User.current().get("ethAddress");
  let amount = Number(document.getElementById("from_amount").value * 10 ** currentTrade.from.decimals);
  if (currentTrade.from.symbol !== "ETH") {
    const allowance = await Moralis.Plugins.oneInch.hasAllowance({
      chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)
      fromTokenAddress: currentTrade.from.address, // The token you want to swap
      fromAddress: address, // Your wallet address
      amount: amount,
    });
    console.log(allowance);
    if (!allowance) {
      await Moralis.Plugins.oneInch.approve({
        chain: "bsc", // The blockchain you want to use (eth/bsc/polygon)
        tokenAddress: currentTrade.from.address, // The token you want to swap
        fromAddress: address, // Your wallet address
      });
    }
  }
  try {
    let receipt = await doSwap(address, amount);
    alert("Swap Complete");
  } catch (error) {
    console.log(error);
  }
}

function doSwap(userAddress, amount) {
  return Moralis.Plugins.oneInch.swap({
    chain: "eth", // The blockchain you want to use (eth/bsc/polygon)
    fromTokenAddress: currentTrade.from.address, // The token you want to swap
    toTokenAddress: currentTrade.to.address, // The token you want to receive
    amount: amount,
    fromAddress: userAddress, // Your wallet address
    slippage: 1,
  });
}

init();

document.getElementById("modal_close").onclick = closeModal;
document.getElementById("from_token_select").onclick = () => {
  openModal("from");
};
document.getElementById("to_token_select").onclick = () => {
  openModal("to");
};
document.getElementById("login_button").onclick = login;
document.getElementById("from_amount").onblur = getQuote;
document.getElementById("swap_button").onclick = trySwap;
<!DOCTYPE html>
<html>
  <head>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <title>Dex Cross function v1 SG</title>
    <script src="https://cdn.jsdelivr.net/npm/web3@latest/dist/web3.min.js"></script>
    <script src="https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4=" crossorigin="anonymous"></script>
    <script src="https://unpkg.com/moralis/dist/moralis.js"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
    <link rel="stylesheet" href="./style.css">
  </head>

  <body>
    <nav class="navbar navbar-expand-lg navbar-light bg-light">
        <a class="navbar-brand" href="#">Decentralized DEX SG</a>
        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
          <span class="navbar-toggler-icon"></span>
        </button>
      
        <div class="collapse navbar-collapse" id="navbarSupportedContent">
          <ul class="navbar-nav mr-auto">
            <li class="nav-item active">
              <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>
            </li>
          </ul>
          <button id="login_button" class="btn btn-outline-primary my-2 my-sm-0" type="submit">Sign in with Metamask</button>
      </div>
    </nav>
  <div class="container">
      <div class="row">
          <div class="col col-md-6 offset-md-3" id="window">
              <h4>Swap</h4>
              <div id="form">
                  <div class="swapbox">
                      <div class="swapbox_select token_select" id="from_token_select">
                          <img class="token_image" id="from_token_img">
                          <span id="from_token_text"></span>
                      </div>
                      <div class="swapbox_select">
                          <input class="number form-control" placeholder="amount" id="from_amount">
                      </div>
                  </div>
                  <div class="swapbox">
                      <div class="swapbox_select token_select"  id="to_token_select">
                          <img class="token_image" id="to_token_img">
                          <span id="to_token_text"></span>
                      </div>
                      <div class="swapbox_select">
                          <input class="number form-control" placeholder="amount" id="to_amount">
                      </div>
                  </div>
                  <div>Estimated Gas: <span id="gas_estimate"></span></div>
                  <button disabled class="btn btn-large btn-primary btn-block" id="swap_button">
                      Swap
                  </button>
              </div>
          </div>
      </div>
  </div>
  <div class="modal" id="token_modal" tabindex="-1" role="dialog">
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <h5 class="modal-title">Select token</h5>
            <button id="modal_close" type="button" class="close" data-dismiss="modal" aria-label="Close">
              <span aria-hidden="true">&times;</span>
            </button>
          </div>
          <div class="modal-body">
            <div id="token_list"></div>
          </div>
        </div>
      </div>
    </div>

  <script type="text/javascript" src="./main.js"></script>
</body>
</html>

Error: Something went wrong
“{\n “statusCode”: 500,\n “message”: “Not enough 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE. Amount: 20000000000000000. Balance: 13226070096633857.”\n}”
at moralis.js:6423:39
at tryCatch (moralis.js:73042:40)
at Generator.invoke [as _invoke] (moralis.js:73273:22)
at Generator.next (moralis.js:73098:21)
at asyncGeneratorStep (moralis.js:29688:24)
at _next (moralis.js:29710:9)

are you trying to transfer? looks like you don’t have enough native token balance

1 Like

the 1inch aggregator needs what native token? 1inch? how is that buyable in the US? so to summarize… the exchange functions only with having 1 inch token already on the wallet. thats not easy to pull off. or do i need binance because im doing 1inch of binance network

that error seems to say that it wants
20000000000000000
and the balance is
13226070096633857

balance of what exactly
?

does this oneinch plugin works with testnet also? I am using BSC Test Net and getting same errror even after lowering token amt to 0.01BNB


async function swap() {
  console.log("Process Initiated");
  console.log("Dex: ", Moralis.Plugins.oneInch);
  try {
    const receipt = await Moralis.Plugins.oneInch.swap({
      chain: NETWORK, // The blockchain you want to use (eth/bsc/polygon)
      fromTokenAddress: NATIVE_ADDRESS, // The token you want to swap
      toTokenAddress: ONEINCH_ADDRESS, // The token you want to receive
      amount: Number(Moralis.Units.ETH("0.01")),
      fromAddress: accountAddress, // Your wallet address
      slippage: 20,
    });
    console.log(receipt);
  } catch (err) {
    console.log(err);
  }
}

The plugin works only on mainnets