Ethereum

практикум

Алер Денисов

Технический директор Musereum.org


Советник и разработчик смарт-контрактов:

  • ACE Token
  • TEAM Token
  • ALT.Estate
  • BROTHER Token

Facebook

fb.com/aler.denisov

Telegram

@alerdenisov

GitHub

github.com/alerdenisov

Telegram Blog

t.me/blockchain_engineers

Повестка дня

Настройка окружения

Настройка вашего компьютера для работы
над смарт-контрактами

Общие понятия

Ознакомление с базовыми принципами работы смарт-контрактов и децентрализованного реестра

«Hello World»

Первый смарт-контракт и взаимодействие с ним

Токенизация

Создание смарт-контракта с использованием
сторонней библиотеки

Гарантия вознаграждения

Смарт-контракт гарантирующий получение адвокатом вознаграждения в случае победы в суде

 

(без централизации и привлечении третий лиц)

Если успеем

Мульти-подпись и отложенная транзакция

(Будет сложно)

Настройка окружения

Mac OS X

Windows

VS Code
+
Solidity Extended
=
❤️

https://code.visualstudio.com/

NodeJS

https://nodejs.org

~/: node --version && npm --version

v9.3.0
5.6.0

Truffle Framework

~/: npm install --global truffle

/usr/local/bin/truffle -> /usr/local/lib/node_modules/truffle/build/cli.bundled.js
+ truffle@4.0.5
added 91 packages in 3.501s

Рабочая директория

/: cd $HOME
~/:  mkdir binary-contracts && cd binary-contracts

~/binary-contracts: truffle init && npm init
Downloading...
Unpacking...
Setting up...
Unbox successful. Sweet!

Commands:

  Compile:        truffle compile
  Migrate:        truffle migrate
  Test contracts: truffle test
~/education/part-01: truffle develop
Truffle Develop started at http://localhost:9545/

Accounts:
(0) 0x627306090abab3a6e1400e9345bc60c78a8bef57
(1) 0xf17f52151ebef6c7334fad080c5704d77216b732
(2) 0xc5fdf4076b8f3a5357c5e395ab970b5b54098fef
(3) 0x821aea9a577a9b44299b9c15c88cf3087f3b5544
(4) 0x0d1d4e623d10f9fba5db95830f7d3839406c6af2
(5) 0x2932b7a2355d6fecc4b5c0b6bd44cc31df247a2e
(6) 0x2191ef87e392377ec08e7c08eb105ef5448eced5
(7) 0x0f4f2ac550a1b4e2280d04c21cea7ebd822934b5
(8) 0x6330a553fc93768f612722bb8c2ec78ac90b3bbc
(9) 0x5aeda56215b167893e80b4fe645ba6d5bab767de

Private Keys:
(0) c87509a1c067bbde78beb793e6fa76530b6382a4c0241e5e4a9ec0a0f44dc0d3
(1) ae6ae8e5ccbfb04590405997ee2d52d2b330726137b875053c36d94e974d162f
(2) 0dbbe8e4ae425a6d2687f1a7e3ba17bc98c673636790f1b8ad91193c05875ef1
(3) c88b703fb08cbea894b6aeff5a544fb92e78a18e19814cd85da83b71f772aa6c
(4) 388c684f0ba1ef5017716adb5d21a053ea8e90277d0868337519f97bede61418
(5) 659cbb0e2411a44db63778987b1e22153c086a95eb6b18bdf89de078917abc63
(6) 82d052c865f5763aad42add438569276c00d3d88a2d062d36b2bae914d58b8c8
(7) aa3680d5d48a8283413f7a108367c7299ca73f553735860a87b08f39395618b7
(8) 0f62d96d6675f32685bbdb8ac13cda7c23436f63efbb9d07700d8669ff12b7c4
(9) 8d5366123cb560bb606379f90a0bfd4769eecc0557f1b362dcae9012b548b1e5

Mnemonic: candy maple cake sugar pudding cream honey rich smooth crumble sweet treat

truffle(develop)>

github.com/alerdenisov/binary-contracts

branch: master

Общие понятия

Смарт-контракты

Инструмент из комплекса инструметов для создания децентрализованных сервисов

Слои децентрализованного сервиса

Блокчейн

Транзакционная
стейт-машина

Любому изменению состояния предшествует валидная транзакция

Необратимый реестр

Любая транзакция принятая сетью в цепочку блоков становится частью реестра и отсутствуют какие-либо инструменты для ее исключения из цепи*

«Пиринговая» сеть

Протокол «сплетен»

Компьютером отправителем сообщения о вашей транзакции может быть любой участник сети

Слой правил учета
и взаимодействия

Правила

  • Консенсус сети об установлении истины
  • Правила записи в реестр (изменения состояния)
  • Правила доступа

Смарт-контракты где-то тут

«Hello World»

pragma solidity ^0.4.18;

contract Greetener {
  // Save address of latest greeter called greet function
  address public lastestGreeter;

  // Greet event fires when someone calls greet function
  event Greet(address indexed _who);
  
  // Greet with everyone inside ethereum blockchain
  function greet() public returns (bool) {
    lastestGreeter = msg.sender;
    Greet(lastestGreeter);
    return true;
  }
}

github.com/
alerdenisov/
binary-contracts

Токенизация

ERC

Ethereum Request for Comments

https://github.com/ethereum/EIPs

Tokens

#20, #223, #721

pragma solidity ^0.4.18;

import 'zeppelin-solidity/contracts/math/SafeMath.sol';
import 'zeppelin-solidity/contracts/token/MintableToken.sol';

contract DistrictToken is MintableToken {
    using SafeMath for uint256;
    
    // ERC20 constants
    string public constant name = "District Token";
    string public constant symbol = "BDT";
    uint public constant decimals = 18;

    uint public constant HARDCAP = 1 ether * 10 ** 9;

    modifier hardCapUnreached(uint _increase) {
      require(totalSupply.add(_increase) <= HARDCAP);
      _;
    }

    function mint(address _to, uint256 _amount) hardCapUnreached(_amount) public returns (bool) {
      return super.mint(_to, _amount);
    }
}

Гарантированное вознаграждение

pragma solidity ^0.4.18;

import 'zeppelin-solidity/contracts/math/SafeMath.sol';
contract RewardCollector {
  using SafeMath for uint256;

  uint public part;
  address public lawyer;
  address public beneficiaries;
  uint public totalyRecovered;

  uint public lawyerConsumed;
  uint public beneficiariesConsumed;

  function RewardCollector(uint _lawyerPart, address _lawyerWallet, address _beneficiariesWallet) public {
    require(_lawyerPart < 10000);
    // Pro bono isn't require smart contract
    require(_lawyerPart > 0);
    
    part = _lawyerPart;
    lawyer = _lawyerWallet;
    beneficiaries = _beneficiariesWallet;
  }

  function () public payable {
    totalyRecovered = totalyRecovered.add(msg.value);
  }

  function withdraw (address _who) public {
    require(_who == lawyer || _who == beneficiaries);
    if (_who == lawyer) {
      withdrawLawyer();
    } else {
      withdrawBeneficiaries();
    }
  }

  function withdrawLawyer () public {
    uint left = totalyRecovered.sub(lawyerConsumed);
    require(left > 0);
    lawyerConsumed = totalyRecovered;
    lawyer.transfer(left.mul(part).div(10000));
  }

  function withdrawBeneficiaries () public {
    uint left = totalyRecovered.sub(beneficiariesConsumed);
    require(left > 0);
    beneficiariesConsumed = totalyRecovered;
    beneficiaries.transfer(left.mul(10000 - part).div(10000));
  }
}

Solidity Docs

Конструкции языка, примеры.

Zeppelin

Базовые контракты с возможностью добавления кастомной логик

JavaScript

ES6-7 с акцентом на возможностях для асинхронного кода

Web3\Ethers

Подписание транзакций, восстановление подписи

Facebook

fb.com/aler.denisov

Telegram

@alerdenisov

GitHub

github.com/alerdenisov

Telegram Blog

t.me/blockchain_engineers

http://bit.ly/2DtDW9v

Ethereum SC

By alerdenisov

Ethereum SC

  • 694