DEV Community

Cover image for ¡Scroll Testnet ya lanzó! 🚀🚀
Ahmed Castro
Ahmed Castro

Posted on • Edited on

¡Scroll Testnet ya lanzó! 🚀🚀

Estamos viviendo en la época de los zkRollups de uso general. En este video exploramos Scroll que es el zkRollup mas fácil de usar porque ofrece una experiencia muy similar a desarrollar en Capa 1.

Actualmente Scroll se encuentra en fase de Alfa cerrado así que si desean ingresar deben ser whitelisteados llenando este formulario.

Antes de comenzar

Para este tutorial ocuparás NodeJs que recomiendo descargarlo en Linux via NVM, y también necesitarás Metamask u otra wallet compatible con la Ethereum Virtual Machine.

1. Agrega las siguientes redes a Metamask

Layer 1 testnet

Nombre de la red: Scroll L1 Testnet
Nueva dirección URL de RPC: https://prealpha.scroll.io/l1
Identificador de cadena: 534351
Símbolo de moneda: TSETH
Dirección URL del explorador de bloques: https://l1scan.scroll.io/

Layer 2 testnet

Nombre de la red: Scroll L2 Testnet
Nueva dirección URL de RPC: https://prealpha.scroll.io/l2
Identificador de cadena: 534354
Símbolo de moneda: TSETH
Dirección URL del explorador de bloques: https://l2scan.scroll.io/

2. Obten fondos desde el facuet

Obten TSETH desde el faucet. Y envía fondos de L1 a L2 a través del bridge.

3. Lanza una Dapp

a. El Smart Contract

Puedes lanzar este Smart Contract desde Remix, asegurate de colocar tu Metamask en Scroll L2.

// SPDX-License-Identifier: MIT
pragma solidity 0.8.17;

contract HelloWorld {
    string public hello = "Hola mundo!";

    function setHello(string memory hello_) public
    {
        hello = hello_;
    }
}
Enter fullscreen mode Exit fullscreen mode

b. El HTML

Ahora en una carpeta nueva crea el archivo html.

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
</head>
<body>
  <input id="connect_button" type="button" value="Connect" onclick="connectWallet()" style="display: none"></input>
  <p id="web3_message"></p>
  <p id="contract_state"></p>
  <h1>Hola Mundo! DApp</h1>
  <p id="hello"></p>
  <input type="input"  value="" id="hello_"></input>
  <input type="button" value="Set Hello" onclick="_setHello()"></input>
  <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/web3/1.3.5/web3.min.js"></script>
  <script type="text/javascript" src="blockchain_stuff.js"></script>
</body>
</html>

<script>
  function _setHello()
  {
    hello_ = document.getElementById("hello_").value
    setHello(hello_)
  }
</script>
Enter fullscreen mode Exit fullscreen mode

c. El Javascript

En la misma carpeta también agrega el archivo Javascript. Observa que estamos usando el id de red 534354. Y recuerda establecer la variable HELLO_WORLD_CONTRACT_ADDRESS con tu address.

blockchain_stuff.js

const NETWORK_ID = 534354
const HELLO_WORLD_CONTRACT_ADDRESS = "ADDRESS DE TU CONTRATO AQUI"
const HELLO_WORLD_ABI_PATH = "./HelloWorld.json"

var helloWorldContract
var accounts
var web3

function metamaskReloadCallback() {
  window.ethereum.on('accountsChanged', (accounts) => {
    document.getElementById("web3_message").textContent="Account changed, refreshing...";
    window.location.reload()
  })
  window.ethereum.on('networkChanged', (accounts) => {
    document.getElementById("web3_message").textContent="Network changed, refreshing...";
    window.location.reload()
  })
}

const getWeb3 = async () => {
  return new Promise((resolve, reject) => {
    if(document.readyState=="complete")
    {
      if (window.ethereum) {
        const web3 = new Web3(window.ethereum)
        window.location.reload()
        resolve(web3)
      } else {
        reject("must install MetaMask")
        document.getElementById("web3_message").textContent="Error: Please connect to metamask";
      }
    }else
    {
      window.addEventListener("load", async () => {
        if (window.ethereum) {
          const web3 = new Web3(window.ethereum)
          resolve(web3)
        } else {
          reject("must install MetaMask")
          document.getElementById("web3_message").textContent="Error: Please install Metamask";
        }
      });
    }
  });
};

const getContract = async (web3, address, abi_path) => {
  const response = await fetch(abi_path);
  const data = await response.json();

  const netId = await web3.eth.net.getId();
  contract = new web3.eth.Contract(
    data,
    address
    );
  return contract
}

async function loadDapp() {
  metamaskReloadCallback()
  document.getElementById("web3_message").textContent="Please connect to Metamask"
  var awaitWeb3 = async function () {
    web3 = await getWeb3()
    web3.eth.net.getId((err, netId) => {
      if (netId == NETWORK_ID) {
        var awaitContract = async function () {
          helloWorldContract = await getContract(web3, HELLO_WORLD_CONTRACT_ADDRESS, HELLO_WORLD_ABI_PATH)
          document.getElementById("web3_message").textContent="You are connected to Metamask"
          onContractInitCallback()
          web3.eth.getAccounts(function(err, _accounts){
            accounts = _accounts
            if (err != null)
            {
              console.error("An error occurred: "+err)
            } else if (accounts.length > 0)
            {
              onWalletConnectedCallback()
            } else
            {
              document.getElementById("connect_button").style.display = "block"
            }
          });
        };
        awaitContract();
      } else {
        document.getElementById("web3_message").textContent="Please connect to Arbitrum Testnet";
      }
    });
  };
  awaitWeb3();
}

async function connectWallet() {
  await window.ethereum.request({ method: "eth_requestAccounts" })
  accounts = await web3.eth.getAccounts()
  onWalletConnectedCallback()
}

loadDapp()

const onContractInitCallback = async () => {
  var hello = await helloWorldContract.methods.hello().call()
  document.getElementById("hello").textContent = hello;
}

const onWalletConnectedCallback = async () => {
}

//// Functions ////

const setHello = async (hello_) => {
  const result = await helloWorldContract.methods.setHello(hello_)
  .send({ from: accounts[0], gas: 0, value: 0 })
  .on('transactionHash', function(hash){
    document.getElementById("web3_message").textContent="Executing...";
  })
  .on('receipt', function(receipt){
    document.getElementById("web3_message").textContent="Success.";    })
  .catch((revertReason) => {
    console.log("ERROR! Transaction reverted: " + revertReason.receipt.transactionHash)
  });
}
Enter fullscreen mode Exit fullscreen mode

d. El JSON ABI

Y finalmente también agrega el archivo JSON ABI.

HelloWorld.json

[
  {
    "inputs": [
      {
        "internalType": "string",
        "name": "hello_",
        "type": "string"
      }
    ],
    "name": "setHello",
    "outputs": [],
    "stateMutability": "nonpayable",
    "type": "function"
  },
  {
    "inputs": [],
    "name": "hello",
    "outputs": [
      {
        "internalType": "string",
        "name": "",
        "type": "string"
      }
    ],
    "stateMutability": "view",
    "type": "function"
  }
]
Enter fullscreen mode Exit fullscreen mode

4. Interactua con el sitio web

npm install -g lite-server
lite-server
Enter fullscreen mode Exit fullscreen mode

Ahora te puedes dirigir a localhost:3000 en tu browser para interactuar con la DApp.

Top comments (0)