Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
スマートコントラクトデザイン / Smart Contract Design
Search
Kenji Saito
PRO
November 06, 2023
Technology
0
110
スマートコントラクトデザイン / Smart Contract Design
2023年11月6日(月)、慶應義塾大学大学院メディアデザイン研究科「サービスデザインプロジェクト B」2023秋で使用したスライドです。
Kenji Saito
PRO
November 06, 2023
Tweet
Share
More Decks by Kenji Saito
See All by Kenji Saito
成果と意思決定 / Performance and Making Decisions
ks91
PRO
0
38
ボランティア / Volunteers
ks91
PRO
0
28
理事会 / Board of Directors
ks91
PRO
0
25
成果 / Achievements
ks91
PRO
0
32
意思決定 / Decision-Making
ks91
PRO
0
28
ファンディングとデジタル市民社会 / Funding and Digital Civil Society
ks91
PRO
0
39
生成AI による論文執筆サポート・ワークショップ 論文執筆・推敲編 / Generative AI-Assisted Paper Writing Support Workshop: Drafting and Revision Edition
ks91
PRO
0
67
私たちの前提は揺るがないのか / Are Our Premises Unshakeable?
ks91
PRO
0
37
貨幣無き世界への過程 / The Process Towards a World without Money
ks91
PRO
0
22
Other Decks in Technology
See All in Technology
AWSの新機能をフル活用した「re:Inventエージェント」開発秘話
minorun365
2
480
Amazon Connect アップデート! AIエージェントにMCPツールを設定してみた!
ysuzuki
0
150
AgentCore BrowserとClaude Codeスキルを活用した 『初手AI』を実現する業務自動化AIエージェント基盤
ruzia
7
1.7k
Oracle Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
3
200
AI との良い付き合い方を僕らは誰も知らない
asei
0
280
『君の名は』と聞く君の名は。 / Your name, you who asks for mine.
nttcom
1
120
まだ間に合う! Agentic AI on AWSの現在地をやさしく一挙おさらい
minorun365
18
2.9k
20251222_サンフランシスコサバイバル術
ponponmikankan
2
140
オープンソースKeycloakのMCP認可サーバの仕様の対応状況 / 20251219 OpenID BizDay #18 LT Keycloak
oidfj
0
200
MySQLのSpatial(GIS)機能をもっと充実させたい ~ MyNA望年会2025LT
sakaik
0
140
20251203_AIxIoTビジネス共創ラボ_第4回勉強会_BP山崎.pdf
iotcomjpadmin
0
140
AI駆動開発ライフサイクル(AI-DLC)の始め方
ryansbcho79
0
200
Featured
See All Featured
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Scaling GitHub
holman
464
140k
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
1
410
Building a Modern Day E-commerce SEO Strategy
aleyda
45
8.4k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
200
Deep Space Network (abreviated)
tonyrice
0
22
GitHub's CSS Performance
jonrohan
1032
470k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.3k
Odyssey Design
rkendrick25
PRO
0
440
YesSQL, Process and Tooling at Scale
rocio
174
15k
Optimising Largest Contentful Paint
csswizardry
37
3.5k
How STYLIGHT went responsive
nonsquared
100
6k
Transcript
generated by Stable Diffusion XL v1.0 B 2023 4 (
) B 2023 — 4 — 2023-11-06 – p.1/74
https://speakerdeck.com/ks91 ( ) ( ) Discord Discord ( / /
) Zoom URL ( ) B 2023 — 4 — 2023-11-06 – p.2/74
( ) 1 10 16 • 2 10 23 •
3 10 30 • 4 11 6 • 5 11 13 1 6 11 20 2 7 11 27 8 12 4 ( ) 4 ( 3 ) ↓ B 2023 — 4 — 2023-11-06 – p.3/74
Ethereum ( ) (1) : ERC20 ( ) (2) :
(3) : Web3 B 2023 — 4 — 2023-11-06 – p.4/74
Ethereum ( ) macOS (Ventura 13.6.1) + Homebrew Linux (Ubuntu
22.04) (x86/AMD64 and ARM) macOS + Lima (Linux Machines) mac M1/M2 (Apple )(ARM) x86/AMD64 Windows 11 + Windows Subsystem for Linux (Ubuntu ) Ethereum solidity brownie B 2023 — 4 — 2023-11-06 – p.5/74
macOS : Homebrew (Apple macOS ) UNIX macOS Lima Homebrew
brew Apple brew ( ) brew Rosetta brew brew https://github.com/homebrew/install Path : https://zenn.dev/tet0h/articles/a92651d52bd82460aefb $ which brew /opt/homebrew/bin/brew B 2023 — 4 — 2023-11-06 – p.6/74
macOS : Rosetta 2 Apple x86/AMD64 ( ) $ softwareupdate
--install-rosetta lima Rosetta 2 lima B 2023 — 4 — 2023-11-06 – p.7/74
macOS : Lima macOS Linux ( ) https://github.com/lima-vm/lima QEMU (
) Rosetta 2 Apple x86/AMD64 brew $ brew install lima Ubuntu 22.04 (x86/AMD64) “kmd.yaml” $ limactl start kmd.yaml B 2023 — 4 — 2023-11-06 – p.8/74
macOS : Lima Linux (Ubuntu) x86_64 $ limactl list Linux
(exit ) $ limactl shell kmd Linux limactl list STATUS Stopped limactl start kmd “.lima” diffdisk 100GB B 2023 — 4 — 2023-11-06 – p.9/74
Solidity Ethereum ( ) http://solidity.readthedocs.io/en/latest/installing-solidity.html Linux (on Windows) “sudo apt”,
macOS “brew” Linux ARM git clone dependencies solc 0.8.21 (10/16 ) $ solc --version brownie py-solc-x solc (dependencies) ( solc py-solc-x ) B 2023 — 4 — 2023-11-06 – p.10/74
Ganache Ethereum RPC npm ( ) macOS https://qiita.com/kyosuke5_20/items/c5f68fc9d89b84c0df09 Linux https://qiita.com/seibe/items/36cef7df85fe2cefa3ea
npm Ganache $ sudo npm install -g ganache B 2023 — 4 — 2023-11-06 – p.11/74
Python3 ( Python3.9 ) macOS $ brew install
[email protected]
Linux
$ sudo add-apt-repository ppa:deadsnakes/ppa $ sudo apt update $ sudo apt install python3.9 python3.9-dev python3.9-venv python3.9-tk B 2023 — 4 — 2023-11-06 – p.12/74
macOS : . . . macOS wget brew dyld: Library
not loaded: /usr/local/opt/gettext/lib/libintl.8.dylib $ brew uninstall --force gettext $ brew install gettext B 2023 — 4 — 2023-11-06 – p.13/74
Python (venv) macOS (Linux python3 ) ‘python3.9’ ‘python3’ $ python3.9
-m venv bbc2env $ source bbc2env/bin/activate (bbc2env) $ pip install -U pip bbc2env ( BBc-2 ) ( ) (bbc2env) $ deactivate B 2023 — 4 — 2023-11-06 – p.14/74
Brownie Python Ethereum https://eth-brownie.readthedocs.io Brownie $ pip install eth-brownie version
1.19.3 (10/16 ) PyYAML $ pip install "cython<3.0.0" wheel && pip install pyyaml==5.4.1 --no-build-isolation B 2023 — 4 — 2023-11-06 – p.15/74
$ brownie init ( ERC-20 ) $ brownie bake token
$ cd token B 2023 — 4 — 2023-11-06 – p.16/74
contracts (macOS Linux (x86/AMD64) ) $ brownie compile Linux (ARM)
(AMD64 ) $ python # >>> import solcx >>> solcx.compile_solc(’0.6.12’) # >>> quit() /tmp ∼/.solcx/solc-v0.6.12 ( ) $ pytest tests B 2023 — 4 — 2023-11-06 – p.17/74
Brownie $ brownie console Python >>> len(accounts) 10 >>> accounts[0].balance()
100000000000000000000 >>> quit() B 2023 — 4 — 2023-11-06 – p.18/74
( ) Ethereum Görli B 2023 — 4 — 2023-11-06
– p.19/74
infura.io Brownie https://infura.io SIGN UP PROJECT ID infura Ethereum API
infura . . . infura.io PROJECT ID WEB3_INFURA_PROJECT_ID PROJECT ID (∼/.bash_profile ) $ export WEB3_INFURA_PROJECT_ID= PROJECT ID B 2023 — 4 — 2023-11-06 – p.20/74
G¨ orli ETH brownie console Görli >>> network.disconnect() >>> network.connect(’goerli’)
>>> len(accounts) 0 >>> accounts.add() mnemonic: ’ ( )’ <LocalAccount object ’ 16 ’> >>> accounts[0].private_key 16 >>> quit() Görli Testnet ETH Faucet ETH https://goerlifaucet.com ( ) ( ) 0.001 ETH Görli ETH B 2023 — 4 — 2023-11-06 – p.21/74
G¨ orli ETH brownie console Görli ETH >>> network.disconnect() >>>
network.connect(’goerli’) >>> len(accounts) 0 >>> accounts.add( 16 ) <LocalAccount object ’ 16 ’> >>> accounts[0].balace() ETH >>> quit() ETH >>> accounts[0].transfer(accounts[1], "0.01 ether") B 2023 — 4 — 2023-11-06 – p.22/74
Ethereum ( ) B 2023 — 4 — 2023-11-06 –
p.23/74
Ethereum Vitalik Buterin, “Ethereum White Paper: A NEXT GENERATION SMART
CONTRACT & DECENTRALIZED APPLICATION PLATFORM” 12 (= ) = ⇒ → Dapps ( / / ) B 2023 — 4 — 2023-11-06 – p.24/74
( ) B 2023 — 4 — 2023-11-06 – p.25/74
. . . B 2023 — 4 — 2023-11-06 –
p.26/74
vs. Ethereum (Ether ) 13 13 B 2023 — 4
— 2023-11-06 – p.27/74
= run B 2023 — 4 — 2023-11-06 – p.28/74
Ether Ethereum EOA : Externally-Owned Account ( ) Ether EVM
EVM B 2023 — 4 — 2023-11-06 – p.29/74
EVM : Ethereum Virtual Machine ঢ়ଶ ֎෦ΞΫλʔ ΞΧϯτ &7. ίʔυ
&UIFSˠ(BT ىಈ ίϯτϥΫτ ϝοηʔδ͔ɺ৽͍ࣗ͠ಈΦϒδΣΫτ ΞΧϯτؒͰΓऔΓ͞ΕΔσʔλ&UIFS ετϨʔδ ঢ়ଶ` τϥϯβΫγϣϯ ηοτ σδλϧॺ໊ &7. ਓؒͱ͔ ࣗಈ ΦϒδΣΫτ Gas ( ( )) . . . B 2023 — 4 — 2023-11-06 – p.30/74
EVM : : ← : Solidity — JavaScript LLL —
Lisp Vyper — Python Fe — Vyper Rust ← NEW! Solidity Vyper Python B 2023 — 4 — 2023-11-06 – p.31/74
Solidity ( ) pragma solidityˆ0.7.0; contract IndivisibleAsset { /* */
string public _name; string public _symbol; uint256 public _quantity; address public _owner; constructor(string memory name, string memory symbol, uint256 quantity) public { _name = name; _symbol = symbol; _quantity = quantity; _owner = msg.sender; } function transfer(address to) public returns (bool) { require (_owner == msg.sender); _owner = to; return true; } } B 2023 — 4 — 2023-11-06 – p.32/74
( , ) (constructor) (deploy) = ( ) ( )
ETH Trusted Actor Model B 2023 — 4 — 2023-11-06 – p.33/74
Ethereum B 2023 — 4 — 2023-11-06 – p.34/74
(1) : ERC20 ( ) $ brownie bake token B
2023 — 4 — 2023-11-06 – p.35/74
pragma solidity ˆ0.6.0; /* 0.8.x */ contract Token { (
) : (EVM ) : constructor (...) public { /* */ : } function balanceOf(...) { /* ( ) */ : } : } constructor C (/* */ // ) B 2023 — 4 — 2023-11-06 – p.36/74
ERC-20 ERC (Ethereum Request for Comments) 20 https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md (EIP: Ethereum
Improvement Proposal) ← EIP ( ) contract ERC20 { function totalSupply() constant returns (uint totalSupply); function balanceOf(address _owner) constant returns (uint balance); function transfer(address _to, uint _value) returns (bool success); function transferFrom(address _from, address _to, uint _value) returns (bool success); function approve(address _spender, uint _value) returns (bool success); function allowance(address _owner, address _spender) constant returns (uint remaining); event Transfer(address indexed _from, address indexed _to, uint _value); event Approval(address indexed _owner, address indexed _spender, uint _value); } name/ , symbol/ , decimals/ approve allowance ERC-777 ( ) B 2023 — 4 — 2023-11-06 – p.37/74
ERC20 ERC20 ( ) ⇒ ERC20 ( ERC20 ) ERC20
⇒ B 2023 — 4 — 2023-11-06 – p.38/74
(fungible) ERC-20 → ERC-223 (draft) or ERC-777 ( )( )
(non-fungible) ERC-721 ( ) ERC-1155 ( ) ERC-3525 (SLOT ) B 2023 — 4 — 2023-11-06 – p.39/74
Token ( ) string public symbol; string public name; uint256
public decimals; uint256 public totalSupply; mapping(address => uint256) balances; . . . name, symbol decimals : 2 100 1.00 mapping balances B 2023 — 4 — 2023-11-06 – p.40/74
Token ( ) event Transfer(address from, address to, uint256 value);
Token function emit Transfer() ( ) B 2023 — 4 — 2023-11-06 – p.41/74
Token ( ) constructor( string memory _symbol, string memory _name,
uint256 _decimals, uint256 _totalSupply ) public { symbol = _symbol; name = _name; decimals = _decimals; totalSupply = _totalSupply; balances[msg.sender] = _totalSupply; } msg.sender _totalSupply B 2023 — 4 — 2023-11-06 – p.42/74
Token balanceOf() function balanceOf(address _owner) public view returns (uint256) {
return balances[_owner]; } B 2023 — 4 — 2023-11-06 – p.43/74
Token transfer() function transfer(address _to, uint256 _value) public returns (bool)
{ balances[msg.sender] = balances[msg.sender].sub(_value); balances[_to] = balances[_to].add(_value); emit Transfer(msg.sender, _to, _value); return true; } ( ↑ ) OpenZeppelin https://openzeppelin.org B 2023 — 4 — 2023-11-06 – p.44/74
(2) : B 2023 — 4 — 2023-11-06 – p.45/74
GitHub git clone $ git clone https://github.com/ks91/sample-smart-contracts.git sample-smart-contracts contracts, scripts
tests token Token Solidity 0.5 0.6/0.7 (Token ) Solidity B 2023 — 4 — 2023-11-06 – p.46/74
(m2 ) 1 1 B 2023 — 4 — 2023-11-06
– p.47/74
IndivisibleAsset string public _name_; string public _symbol_; uint256 public _quantity_;
address public _owner_; _name_ ( ) _symbol_ _quantity_ (m2 ) _owner_ ‘_’ Solidity . . . B 2023 — 4 — 2023-11-06 – p.48/74
IndivisibleAsset event Transfer(address indexed from, address indexed to); from to
indexed B 2023 — 4 — 2023-11-06 – p.49/74
IndivisibleAsset constructor (string name, string symbol, uint256 quantity) public {
_name_ = name; _symbol_ = symbol; _quantity_ = quantity; _owner_ = msg.sender; } B 2023 — 4 — 2023-11-06 – p.50/74
IndivisibleAsset getOwner() function getOwner() public view returns (address) { return
(_owner_); } B 2023 — 4 — 2023-11-06 – p.51/74
IndivisibleAsset transfer() function transfer(address to) public returns (bool) { require(_owner_
== msg.sender); _owner_ = to; emit Transfer(msg.sender, to); return true; } require (function ) ( ) $ brownie compile B 2023 — 4 — 2023-11-06 – p.52/74
scripts/indivisible asset.py from brownie import * def main(): accounts[0].deploy(IndivisibleAsset, "5322
Endo, Fujisawa", "mˆ2", 300) SFC (300m2 ) ( ) B 2023 — 4 — 2023-11-06 – p.53/74
from brownie import * import pytest def test_owner_and_transfer(IndivisibleAsset): asset =
accounts[0].deploy(IndivisibleAsset, "5322 Endo", "mˆ2", 300) assert asset.getOwner() == accounts[0] asset.transfer(accounts[1], {’from’: accounts[0]}) assert asset.getOwner() == accounts[1] try: asset.transfer(accounts[0], {’from’: accounts[0]}) done = 1 except: done = 0 assert done == 0 accounts[0] accounts[1] B 2023 — 4 — 2023-11-06 – p.54/74
$ pytest tests/test_indivisible_asset.py B 2023 — 4 — 2023-11-06 –
p.55/74
(3) : B 2023 — 4 — 2023-11-06 – p.56/74
transfer settle, retrieve asset, retrieve token 3 B 2023 —
4 — 2023-11-06 – p.57/74
1. ( ) 2. ( ) 3. ( ) B
2023 — 4 — 2023-11-06 – p.58/74
OneTimeEscrow settle() function settle() public returns (bool) { require(_token_.balanceOf(address(this)) >=
_price_); /* this */ require(_asset_.getOwner() == address(this)); _token_.transfer(_seller_ , _price_); _asset_.transfer(_buyer_); emit Settled(); /* */ return true; } settle() transfer ( / ) $ brownie compile B 2023 — 4 — 2023-11-06 – p.59/74
(1) from brownie import * import pytest def test_deploy_and_settle(Token, IndivisibleAsset,
OneTimeEscrow): asset = accounts[0].deploy(IndivisibleAsset, "5322 Endo", "mˆ2", 300) token = accounts[0].deploy(Token, "Test Token", "TEST", 18, "1000 ether") B 2023 — 4 — 2023-11-06 – p.60/74
(2) token.transfer(accounts[1], 300, {’from’: accounts[0]}) escrow = accounts[0].deploy(OneTimeEscrow, token, accounts[1],
asset, accounts[0], 300) accounts[0] accounts[1] 300 300 TX accounts[1] accounts[0] 300 bake Token 300 ETH wei B 2023 — 4 — 2023-11-06 – p.61/74
(3) token.transfer(escrow, 300, {’from’: accounts[1]}) asset.transfer(escrow, {’from’: accounts[0]}) assert token.balanceOf(accounts[0])
== 999999999999999999700 assert token.balanceOf(accounts[1]) == 0 assert token.balanceOf(escrow) == 300 assert asset.getOwner() == escrow accounts[1] ( ) 300 accounts[0] ( ) B 2023 — 4 — 2023-11-06 – p.62/74
(4) escrow.settle({’from’: accounts[0]}) assert token.balanceOf(accounts[0]) == 1000000000000000000000 assert token.balanceOf(accounts[1]) ==
0 assert token.balanceOf(escrow) == 0 assert asset.getOwner() == accounts[1] settle() accounts[0] OK B 2023 — 4 — 2023-11-06 – p.63/74
$ pytest tests/test_one_time_escrow.py : settle() ⇒ Discord B 2023 —
4 — 2023-11-06 – p.64/74
B 2023 — 4 — 2023-11-06 – p.65/74
1. (1) (2) Ethereum 2023 11 4 ( ) 23:59
JST B 2023 — 4 — 2023-11-06 – p.66/74
. . . . . . 2 0 ( )
( ) ↓ ( ) B 2023 — 4 — 2023-11-06 – p.67/74
⇒ 20 Discord . . . B 2023 — 4
— 2023-11-06 – p.68/74
Web3 Web3 HTTPS B 2023 — 4 — 2023-11-06 –
p.69/74
B 2023 — 4 — 2023-11-06 – p.70/74
miro ( ) ( ) B 2023 — 4 —
2023-11-06 – p.71/74
B 2023 — 4 — 2023-11-06 – p.72/74
2. API (1) ( ) (2) Web API 2023 11
11 ( ) 23:59 JST B 2023 — 4 — 2023-11-06 – p.73/74
B 2023 — 4 — 2023-11-06 – p.74/74