Использование Web3

Введение

В этом руководстве рассматривается процесс использования Web3 для ручной подписи и отправки транзакции на узел разработки Edgeware EVM. В этом примере мы будем использовать Node.js и простой код JavaScript.

Примечание Это руководство было создано с использованием версии Edgeware EVM. Платформа Edgeware EVM и компоненты Frontier, на которые она опирается для совместимости Ethereum на основе субстрата, все еще находятся в стадии активной разработки. Мы создали это руководство, чтобы вы могли протестировать функции совместимости Edgeware с Ethereum. Несмотря на то, что мы все еще находимся в разработке, мы считаем важным, чтобы заинтересованные члены сообщества и разработчики имели возможность начать пробовать что-то с Edgeware и оставлять отзывы.

Проверка предпосылок

Установлен Nodejs и конкретный менеджер пакетов, например yarn или npm, остальные батареи включены в это руководство. В этом руководстве предполагается, что у вас есть [работающий локальный узел Edgeware EVM, работающий в режиме --dev]. контракт-evm/настройка-узла-edgeware-evm).

git clone https://github.com/edgeware-builders/tutorials tutorials;cd tutorials/web3;yarn

Он переместится в ваш клонированный репозиторий, установит необходимые пакеты, и вы готовы к работе!

Создание транзакции

В этом примере нам нужен только один файл JavaScript для создания транзакции, которую мы запустим с помощью команды «node» в терминале. Скрипт переведет 1337 ETH с аккаунта Genesis на другой адрес. Для простоты файл разделен на три раздела: определение переменных, создание транзакций и трансляция транзакций.

Нам нужно установить пару значений в определениях переменных:

const Web3 = require('web3');

// genesis private key
const privKey = '1111111111111111111111111111111111111111111111111111111111111111';
const addressFrom = '0x19e7e376e7c213b7e7e7e46cc70a5dd086daff2a';
const addressTo = '0x6bB5423f0Dd01B8C5028a1bc01e1f1bDe4523e72';
const web3 = new Web3('http://localhost:9933/');

Оба раздела create transaction и deploy transaction заключены в асинхронную функцию, которая обрабатывает промисы из нашего экземпляра Web3. Чтобы создать транзакцию, мы используем команду web3.eth.accounts.signTransaction(tx, privKey), где мы должны определить объект tx с некоторыми параметрами, такими как: addressFrom, addressTo, `количество токенов для отправки» и «лимит газа».

const deploy = async () => {
  console.log(
    `Attempting to make transaction from ${addressFrom} to ${addressTo}`
  );

  const createTransaction = await web3.eth.accounts.signTransaction(
    {
      from: addressFrom,
      to: addressTo,
      value: web3.utils.toWei('1337', 'ether'),
      gas: 21000,
    },
    privKey
  );

Полный createTransaction.js должен выглядеть так!

const Web3 = require('web3');

// genesis private key
const privKey = '1111111111111111111111111111111111111111111111111111111111111111';
const addressFrom = '0x19e7e376e7c213b7e7e7e46cc70a5dd086daff2a';
const addressTo = '0x6bB5423f0Dd01B8C5028a1bc01e1f1bDe4523e72';
const web3 = new Web3('http://localhost:9933/');

// Create transaction
const deploy = async () => {
  console.log(
    `Attempting to make transaction from ${addressFrom} to ${addressTo}`
  );

  const createTransaction = await web3.eth.accounts.signTransaction(
    {
      from: addressFrom,
      to: addressTo,
      value: web3.utils.toWei('1337', 'ether'),
      gas: 21000,
    },
    privKey
  );

  // Deploy transaction
  const createReceipt = await web3.eth.sendSignedTransaction(
    createTransaction.rawTransaction
  );
  console.log(
    `Transaction successful with hash: ${createReceipt.transactionHash}`
  );
  process.exit(0);
};

deploy();

Проверить баланс на счетах

Перед запуском скрипта нам нужен еще один файл для проверки балансов обоих адресов до и после выполнения транзакции. Мы можем легко сделать это, используя функции совместимости Edgeware с Ethereum.

balances.js выглядит так:

const Web3 = require('web3');

// Variables definition
const addressFrom = '0x19e7e376e7c213b7e7e7e46cc70a5dd086daff2a';
const addressTo = '0x6bB5423f0Dd01B8C5028a1bc01e1f1bDe4523e72';
const web3 = new Web3('http://127.0.0.1:9933');

// Balance call
const balances = async () => {
  const balanceFrom = web3.utils.fromWei(
    await web3.eth.getBalance(addressFrom),
    'ether'
  );
  const balanceTo = await web3.utils.fromWei(
    await web3.eth.getBalance(addressTo),
    'ether'
  );

  console.log(`The balance of ${addressFrom} is: ${balanceFrom} ETH.`);
  console.log(`The balance of ${addressTo} is: ${balanceTo} ETH.`);
};

balances();Copy to clipboardErrorCopied

Время игры

Запустите node balance.js, чтобы проверить начальный баланс на счетах.

*web3-init-balance

Запустите node createTransaction.js, чтобы передать некоторые вещи по цепочке

*web3-make-transaction

Запустите node balance.js, чтобы проверить баланс результатов

*web3-result-balance

Свяжитесь с нами для большего вовлечения

Рад, что вы прошли через это! 🥰 Мы стремимся помочь вам в ваших исследованиях с помощью функции расчесывания Edgeware Ethereum. Мы будем рады узнать о вашем опыте и предложениях, которые вы можете нам предложить.. Вы можете свободно общаться с нами в каналах Edgeware, таких как Discord, Element и Telegram, мы можем помочь вам с проблемами, которые могут у вас возникнуть, или с проектом, который вы хотите финансировать. через нашу программу казначейства. Не стесняйтесь делиться своими отзывами на наших каналах, всегда есть место для улучшения! 🙌