Ethereum
практикум
Алер Денисов
Технический директор Musereum.org
Советник и разработчик смарт-контрактов:
- ACE Token
- TEAM Token
- ALT.Estate
- BROTHER Token
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
Подписание транзакций, восстановление подписи
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