Public functions
Internal functions
Web3 call functions
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George [email protected]
@dev Contract constructor sets initial owners , required number confirmations daily withdraw limit
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
Verix Chain
Symbol : Verix
Name : Verix Chain
Total supply : 33333333333
Decimals :
Decentralized monetary powered Ethereum
future !
( c ) Verix Chain 2018
( UPDATED CONTRACT FIX SOMEBUG )
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
CHANGE Update contract name
Token Name
many decimals show standard complicant keep 18
identifier : eg SBX , XPR etc
many units coin bought 1 ETH ?
WEI smallest unit ETH ( equivalent cent USD satoshi BTC ) We'll store total ETH raised via ICO
raised ETH go ?
constructor function
means following function name match contract name declared
Give creator initial tokens set 1000 example want initial tokens X decimal 5 , set value X * 100000 ( CHANGE )
Update total supply ( 1000 example ) ( CHANGE )
Set name display purposes ( CHANGE )
Amount decimals display purposes ( CHANGE )
Set symbol display purposes ( CHANGE )
Set price token ICO ( CHANGE )
owner contract gets ETH
Broadcast message blockchain
Transfer ether funds Wallet
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

slight change ERC20 base standard
function total Supply ( ) constant returns ( uint256 supply ) ;
replaced :
uint256 public total Supply;
automatically creates getter function total Supply
moved base contract since public getter functions
currently recognised implementation matching abstract
function compiler
LUXREUM tokens Math operations safety checks avoid unnecessary conflicts
dev Ownable constructor sets original `owner` contract sender
account
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
LUXREUM Smart contract based full ERC20 Token standard
https : github ethereum EIPs issues 20
Verified Status : ERC20 Verified Token
LUXREUM Symbol : LXR
total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Saftey Checks Multiplication Tasks
Saftey Checks Divison Tasks
Saftey Checks Subtraction Tasks
Saftey Checks Addition Tasks
validates address currently checks null
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
Check allowance
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
github ethereum EIPs issues 20 issuecomment 263524729 *
Notify anyone listening approval done
2 Billion tokens , 18 decimal places ,
Give creator initial tokens
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
TEAM X Rights Received http : teamx club
product protected license unauthorized copy , modification , use without
express written consent creators prohibited
cooperation Please email : [email protected]
| | ( ||| | \ , ( ) | | | | ( | ( | Main Contract
5% fee buy sell
shares
keeps 30%
| ) | || ) || ( ~|~| || | ( | | ( ) | | \ public functions
\ | ( VV ~|~| || | ( | | ( ) | | \ view functions
| ) | |\ ( | | ( ~|~| || | ( | | ( ) | | \ private functions
Gas optimization : cheaper asserting 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
assert ( b 0 ) ; Solidity automatically throws dividing 0
uint256 c = b;
assert ( == b * c + % b ) ; case hold

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

https : fortisgames https : fortisgames https : fortisgames https : fortisgames https : fortisgames
FFFFFFFFFFFFFFFFFFFFFF tttt iiii
F : : : : : : : : : : : : : : : : : : : : F ttt : : : : : : :
F : : : : : : : : : : : : : : : : : : : : F : : : : : iiii
FF : : : : : : FFFFFFFFF : : : : F : : : : :
F : : : : : F FFFFFFooooooooooo rrrrr rrrrrrrrr ttttttt : : : : : ttttttt iiiiiii ssssssssss
F : : : : : F oo : : : : : : : : : : : oo r : : : : rrr : : : : : : : : : r : : : : : : : : : : : : : : : : : : : : : : ss : : : : : : : : : :
F : : : : : : FFFFFFFFFFo : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : r : : : : : : : : : : : : : : : : : : : : : ss : : : : : : : : : : : : :
F : : : : : : : : : : : : : : : Fo : : : : : ooooo : : : : : orr : : : : : : rrrrr : : : : : : rtttttt : : : : : : : tttttt : : : : : : : : : : ssss : : : : :
F : : : : : : : : : : : : : : : Fo : : : : : : : : r : : : : : r r : : : : : r : : : : : : : : : : : : : : ssssss
F : : : : : : FFFFFFFFFFo : : : : : : : : r : : : : : r rrrrrrr : : : : : : : : : : : : : : :
F : : : : : F : : : : : : : : r : : : : : r : : : : : : : : : : : : : : :
F : : : : : F : : : : : : : : r : : : : : r : : : : : tttttt : : : : ssssss : : : : :
FF : : : : : : : FF : : : : : ooooo : : : : : r : : : : : r : : : : : : tttt : : : : : ti : : : : : : : : : : : ssss : : : : : :
F : : : : : : : : FF : : : : : : : : : : : : : : : r : : : : : r tt : : : : : : : : : : : : : : ti : : : : : : : : : : : : : : : : : : : :
F : : : : : : : : FF oo : : : : : : : : : : : oo r : : : : : r tt : : : : : : : : : : : tti : : : : : : : : : : : : : : : : : ss
FFFFFFFFFFF ooooooooooo rrrrrrr ttttttttttt iiiiiiii sssssssssss
Discord : https : discord gg g Dt TX62
interactive , variable dividend rate contract ICO capped price floor collectibles
Bankroll contract , containing tokens purchased dividend card profit ICO dividends
Acts token repository games Zethr platform
= EVENTS =
= WITHDRAWAL CONSTANTS =
= ZTH INTERFACE =
= VARIABLES =
= CUSTOM CONSTRUCTS =
= MODIFIERS =
= LIST OWNERS =
list reference identification purposes , comprises eight core Zethr developers
game contracts listed , must approved majority ( e currently five ) owners
Contracts delisted emergency single owner
0x4F4e BF556CFDc21c3424F85ff6572C77c514Fcae Norsefire
0x11e52c75998fe2E7928B191bfc5B25937Ca16741 klob
0x20C945800de43394F70D789874a4da C9c FA57451 Etherguy
0xef764BAC8a438E7E498c2E5fc Cf0f174c3E3F8d B blurr
0x8537aa2911b193e5B377938A723D805bb0865670 oguzhanox
0x9D221b2100Cb E5F05a0d2048E2556a6Df6f9a6C3 Randall
0x71009e9E4e5e68e77ECc7ef2f2E95cb D98c6E696 cryptodude
0x Da83156106c4dba7A26E9b F2Ca91E273350aa551 Tropical Rogue
= PUBLIC FUNCTIONS =
Testing
function exit ( )
public
uint token Balance = ZTHTKN balance ( address ( ) ) ;
ZTHTKN sell ( token Balance 1e18 ) ;
ZTHTKN sell ( 1e18 ) ;
ZTHTKN withdraw ( address ( 0x0 ) ) ;
amount Tokens
data
= OPERATOR FUNCTIONS =
Web3 call functions
= UTILITIES =
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
fortisgames https : fortisgames https : fortisgames https : fortisgames https : fortisgames
discord gg g Dt TX62
Norsefire
klob
Etherguy
blurr
oguzhanox
Randall
cryptodude
Tropical Rogue
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Fallback function allows Ether deposited
@dev Function buy tokens contract eth balance
Nothing , receives tokens
@dev Calculates amount tokens exceeds aggregate daily limit 15% contract
balance 5% contract balance
@dev Allows us set daily Token Limit
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
Additions Bankroll
set daily tokens particular contract separate call
Remove whitelisted contract exception norm
invoked directly owner , event game found
bugged otherwise faulty , shut emergency measure
Iterates whitelisted contracts find contract Address ,
swaps last address list decrements length
Alters amount tokens allocated game contract daily basis
Function run owner ( ideally cron job ) performs daily
token collection dispersal whitelisted contracts
event want manually take tokens back whitelisted contract ,
Dispenses daily amount ZTH whitelisted contract , retrieves excess
Block withdraws greater MAX WITHDRAW PCT TX Zethr token balance
( May require occasional adjusting daily token allocation contracts )
Make sure tokens sent contract black
need send tokens , make sure permitted amount , send
Make sure amount = tokenbalance*MAX WITHDRAW PCT TX
contract question made profit : retrieve excess tokens
Dev withdrawal tokens splits equally among owners contract
Change dividend card address Can't see would ever need
invoked , better safe sorry
Receive Ether ( Zethr source ) purchase tokens 33% dividend rate
amount less 0 01 Ether , Ether stored contract balance
exceeds limit purchases
Use available balance buy
Convert hexadecimal character value
Convert hexadecimal string raw bytes
length must even
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

Summary :
Artifact Chain next generation digital asset bank world's first public chain project focuses business application encrypted digital asset industry conducts global coordination based blockchain networks decentralized smart financial platform providing global users precise digital asset issuance , trading , management related services Artifact Chain , aim solve issues complexity digital asset issuance asset digitization , ease digital asset loss , limited capacity public chains , excessive cost blockchain transactions , lack user privacy protection , lack truth consistency linkage chain digital assets physical assets Artifact Chain endows business blockchain unlimited capacity , extremely low cost , ability protect commercial secrets end , Artifact Chain aspires connect business scenes different countries blockchain technology , achieving effective cooperation worldwide hope provide kinds digital financial services precisely needed global user using data smart technology future Artifact Chain next generation digital asset bank , forged construct next generation intelligent financial ecosystem
Title : Safe Math
Dev : Math operations safety checks throw error
ERC223 contract interface ERC20 functions events
Fully backward compatible ERC20
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
github Dexaran ERC223 token standard tree Recommended
Function access name token
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

mitigates ERC20 short address attack

title Safe Math
title Ownable
dev Ownable constructor sets original `owner` contract
sender account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title ERC223
title Contract Receiver
title Fight Money
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
ERC223 ERC20 functions events
ERC223 functions
ERC20 functions events

Elyxr
[x] 0% TRANSFER FEES ! allows tokens used future games taxed
[X] 10% DIVIDENDS MASTERNODES !
[x] 5% Jackpot Fee
50% Jackpot goes winner discord 50% used buy back exchange give divs token
holders make sure HODL !
[x] DAPP INTEROPERABILITY , games APPs incorporate Elyxr tokens !
Definition contract accepting Elyxr tokens
Games , casinos , anything reuse contract support Elyxr tokens
dev Standard ERC677 function handle incoming token transfers
param Token sender address
param value Amount tokens
param data Transaction metadata
= MODIFIERS =
= EVENTS =
= CONFIGURABLES =
= DATASETS =
= PUBLIC FUNCTIONS =
APPLICATION ENTRY POINTS
Converts incoming ethereum tokens caller , passes referral addy ( )
Fallback function handle ethereum send straight contract
Unfortunately cannot use referral address way
Sends Jackpot funds additional dividends
Jackpot Address : https : etherscan address 0x083EA7627ED7F4b48E7a FA3AF552cd30B2Dff3af
Converts caller's dividends tokens
Alias sell ( ) withdraw ( )
Withdraws callers earnings
Liquifies tokens ethereum
Transfer tokens caller new holder
REMEMBER 0% TRANSFER FEE
Transfer token specified address forward data recipient
ERC 677 standard
https : github ethereum EIPs issues 677
param Receiver address
param value Amount tokens transferred
param data Transaction metadata
Additional check game address sending tokens contract
assemble given address bytecode bytecode exists addr contract
ADMINISTRATOR FUNCTIONS
case amassador quota met , administrator manually disable ambassador phase
case one us dies , need replace
Precautionary measures case need adjust masternode rate
Add remove game contract , accept Elyxr tokens
want rebrand ,
want rebrand ,
HELPERS CALCULATORS
Method view current Ethereum stored contract
Example : total Ethereum Balance ( )
Retrieve total token supply
Retrieve tokens owned caller
Retrieve dividends owned caller
` include Referral Bonus` 1 true , referral bonus included calculations
reason , frontend , want get total divs ( global + ref )
internal calculations , want separate
Retrieve token balance single address
Retrieve dividend balance single address
Return buy price 1 individual token
Return sell price 1 individual token
Function frontend dynamically retrieve price scaling buy orders
Function frontend dynamically retrieve price scaling sell orders
Function frontend show ether waiting sent Jackpot contract
= INTERNAL FUNCTIONS =
Calculate Token price based amount incoming ethereum
algorithm , hopefully gave whitepaper scientific notation;
conversions occurred prevent decimal errors underflows overflows solidity code
Calculate token sell value
algorithm , hopefully gave whitepaper scientific notation;
conversions occurred prevent decimal errors underflows overflows solidity code
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
people tokens
people profits
administrators :
change name contract
change name token
change Po difficulty ( many tokens costs hold masternode , case gets crazy high later )
CANNOT :
take funds
disable withdrawals
kill contract
change price tokens
ensures first tokens contract equally distributed
meaning , divine dump ever possible
result : healthy longevity
still vulnerable phase ?
, enact anti early whale protocol
customer ambassador list ?
customer purchase exceed max ambassador quota ?
updated accumulated quota
execute
case ether count drops low , ambassador phase reinitiate
ERC20
10% dividend fee buy sell
5% Jackpot fee buy sell
Address send Jackpot
total ETH Jackpot recieved contract
total ETH Jackpot collected contract
proof stake ( defaults 100 tokens )
ambassador program
ambassor quota met , disable open public
amount shares address ( scaled number )
administrator list ( see )
set true , ambassadors purchase tokens ( prevents whale premine , ensures fairly distributed upper pyramid )
Special Elyxr Platform control scam game contracts Elyxr platform
contracts , accept Elyxr tokens
add administrators
add ambassadors
ambassador Dev
ambassador TR
ambassador FF
ambassador YB
ambassador CA
ambassador KH
etherscan address 0x083EA7627ED7F4b48E7a FA3AF552cd30B2Dff3af
fetch dividends
retrieve ref bonus later code
pay dividends virtually
retrieve ref bonus
dispatch buy order virtualized "withdrawn dividends"
fire event
get token count caller & sell
lambo delivery service
setup data
get ref bonus later code
update dividend tracker
add ref bonus
lambo delivery service
fire event
setup data
russian hackers BTFO
Take dividends jackpot Payout
Add ethereum send Jackpot
burn sold tokens
update dividends tracker
dividing zero bad idea
update amount dividends per token
fire event
setup
make sure requested tokens
also disables transfers ambassador phase
( dont want whale premines )
withdraw outstanding dividends first
exchange tokens
update dividend trackers
fire event
ERC20
github ethereum EIPs issues 677
security check contract approved Elyxr platform
normal token transfer contract
retrieve size code target address , needs assembly
calculation relies token supply , need supply Doh
calculation relies token supply , need supply Doh
Make sure send back excess user sends 4 ether 100 ETH contract
contracts allowed
check transaction 4 ether
check contract less 100 ether
data setup
point continuing execution OP poorfag russian hacker
prevents overflow case pyramid somehow magically starts used everyone world
( hackers )
yes know safemath function automatically rules "greater then" equasion
user referred masternode ?
referred purchase ?
cheating !
referrer least X whole tokens ?
e referrer godly chad masternode
wealth redistribution
ref purchase
add referral bonus back global dividends cake
can't give people infinite ethereum
add tokens pool
take amount dividends gained transaction , allocates evenly shareholder
calculate amount tokens customer receives purchase
add tokens pool
update circulating supply & ledger address customer
Tells contract buyer deserve dividends tokens owned them;
really know think
fire event
underflow attempts BTFO
underflow attempts BTFO
gas goes , sorry
sorry , probably paid 1 gwei
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

mitigates ERC20 short address attack

compiler : 0 4 21+commit dfe3193c Emscripten clang
ERC20 Token ERC223 Token compatibility
Safe Math Open Zeppelin Standard
Added burn functions Ethereum Token
https : theethereum wiki w index php ERC20 Token Standard
https : github Dexaran ERC23 tokens blob Recommended ERC223 Token sol
https : github Open Zeppelin openzeppelin solidity blob master contracts math Safe Math sol
https : www ethereum org token ( uncontrolled , non standard )
ERC223
Safe Math
Rune Characteristics
Mapping
Minting event
accept money
ERC20
ERC20
ERC20
recommended fix known attack ERC20
current allowance spender equal current Value ,
overwrite value return true , otherwise return false
ERC20
ERC20
null
ERC20
ERC223 Transfer invoke specified callback
ERC223 Transfer contract externally owned account
ERC223 Transfer contract invoke token Fallback ( ) method
ERC223 fetch contract size ( must nonzero contract )
catch overflow
Transfer ( , , value , data ) ; ERC223 compat version
ERC20 compat version
Ethereum Token
Ethereum Token
Ethereum Token

mitigates ERC20 short address attack

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
CHANGE Update contract name
Token Name
many decimals show standard complicant keep 18
identifier : eg SBX , XPR etc
many units coin bought 1 ETH ?
WEI smallest unit ETH ( equivalent cent USD satoshi BTC ) We'll store total ETH raised via ICO
raised ETH go ?
constructor function
means following function name match contract name declared
Give creator initial tokens set 1000 example want initial tokens X decimal 5 , set value X * 100000 ( CHANGE )
Update total supply ( 1000 example ) ( CHANGE )
Set name display purposes ( CHANGE )
Amount decimals display purposes ( CHANGE )
Set symbol display purposes ( CHANGE )
Set price token ICO ( CHANGE )
owner contract gets ETH
Broadcast message blockchain
Transfer ether funds Wallet
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization
control functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract
sender account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
Function access name token
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC223 interface
title ERC223 token handler
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Throws called account owner
dev Ownable constructor sets original `owner` contract sender
account
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title Pausable
dev Base contract allows children implement emergency stop mechanism
dev Modified function 'final Unpause'
dev Modifier make function callable contract paused
dev Modifier make function callable contract paused
dev called owner pause , triggers stopped state
dev called owner unpause , returns normal state
func unpause final Unpause stuff except event
see effect
title Burnable Token
dev Token irreversibly burned ( destroyed )
dev Burns specific amount tokens
param value amount token burned
title Tipcoin contract
dev transfer token specified address call custom function external data
param address transfer
param value amount transferred
param data data call token Fallback function
param fallback function name params call external function
dev transfer token specified address external data
param address transfer
param value amount transferred
param data data call token Fallback function
dev transfer token specified address
param address transfer
param value amount transferred
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
File : contracts zeppelin math Safe Math sol
assert ( b 0 ) ; Solidity automatically throws dividing 0
uint256 c = b;
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 179
github ethereum EIPs issues 20
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
final Unpaused always false , sure purpose
required , sub method take care
require ( value = balances[ who] ) ;
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
owner already initiated ownable constructor
owner = msg sender;
@dev internal part

PLAYER DATA
mapping ( address = uint256 ) public p IDx Addr ; ( addr = p ID ) returns player id address
mapping ( bytes32 = uint256 ) public p IDx Name ; ( name = p ID ) returns player id name
mapping ( uint256 = POOHMOXDatasets Player ) public plyr ; ( p ID = data ) player data
mapping ( uint256 = mapping ( uint256 = POOHMOXDatasets Player Rounds ) ) public plyr Rnds ; ( p ID = r ID = data ) player round data player id & round id
mapping ( uint256 = mapping ( bytes32 = bool ) ) public plyr Names ; ( p ID = name = bool ) list names player owns ( used change display name amongst name )
ROUND DATA
mapping ( uint256 = POOHMOXDatasets Round ) public round ; ( r ID = data ) round data
mapping ( uint256 = mapping ( uint256 = uint256 ) ) public rnd Tm Eth ; ( r ID = ID = data ) eth per team , round id team id
TEAM FEE DATA
mapping ( uint256 = POOHMOXDatasets Team Fee ) public fees ; ( team = fees ) fee distribution team
mapping ( uint256 = POOHMOXDatasets Pot Split ) public pot Split ; ( team = fees ) pot split distribution team
( ( ) | | \ | | | | ( | ( ) | ( initial data setup upon contract deploy )
constructor ( address whale Contract , address playerbook )
public
flush Divs = whale Contract;
Player Book = Player Book Interface ( playerbook ) ;
teams POOH heads
Referrals Community rewards mathematically designed come winner's share pot
fees [0] = POOHMOXDatasets Team Fee ( 39 , 20 ) ; 30% pot , 10% aff , 1% dev ,
pot Split [0] = POOHMOXDatasets Pot Split ( 15 , 10 ) ; 36% winner , 36% next round , 3% dev
| | | ( ) ( ||~|~| ( | \ ( safety checks )
dev used make sure one interact contract
activated
dev prevents contracts interacting fomo3d
dev sets boundaries incoming tx
dev emergency buy uses last stored affiliate ID
dev converts incoming ethereum keys
functionhash 0x8f38f309 ( using ID affiliate )
functionhash 0x98a0871d ( using address affiliate )
functionhash 0xa65b37a1 ( using name affiliate )
param aff Code ID address name player gets affiliate fee
dev essentially buy , instead sending ether
wallet , uses unwithdrawn earnings
functionhash 0x349cdcac ( using ID affiliate )
functionhash 0x82bfc739 ( using address affiliate )
functionhash 0x079ce327 ( using name affiliate )
param aff Code ID address name player gets affiliate fee
param eth amount earnings use ( remainder returned gen vault )
dev withdraws earnings
functionhash 0x3ccfd60b
dev use register names wrappers send
registration requests Player Book contract registering
registering UI always display last name registered
still previously registered names use affiliate
links
must pay registration fee
name must unique
names converted lowercase
name cannot start end space
cannot 1 space row
cannot numbers
cannot start 0x
name must least 1 char
max length 32 characters long
allowed characters : z , 0 9 , space
functionhash 0x921dec21 ( using ID affiliate )
functionhash 0x3ddd4698 ( using address affiliate )
functionhash 0x685ffd83 ( using name affiliate )
param name String players desired name
param aff Code affiliate ID , address , name referred
param set true want push info games
( might cost lot gas )
dev return price buyer pay next 1 individual key
functionhash 0x018a25e8
return price next key bought ( wei format )
dev returns time left dont spam , ddos node
provider
functionhash 0xc7e284b8
return time left seconds
dev returns player earnings per vaults
functionhash 0x63066434
return winnings vault
return general vault
return affiliate vault
solidity hates stack limits lets us avoid hate
dev returns current round info needed front end
functionhash 0x747dff42
return eth invested ICO phase
return round id
return total keys round
return time round ends
return time round started
return current pot
return current team ID & player ID lead
return current player leads address
return current player leads name
return whales eth round
return bears eth round
return sneks eth round
return bulls eth round
dev returns player info based address address given ,
use msg sender
functionhash 0xee0b5d8b
param addr address player want lookup
return player ID
return player name
return keys owned ( current round )
return winnings vault
return general vault
return affiliate vault
return player round eth
dev logic runs whenever buy order executed determines handle
incoming eth depending active round
dev logic runs whenever reload order executed determines handle
incoming eth depending active round
dev core logic buy reload happens round
live
dev calculates unmasked earnings ( calculates , update mask )
return earnings wei format
dev returns amount keys would get given amount eth
functionhash 0xce89c80c
param r ID round ID want price
param eth amount eth sent
return keys received
dev returns current eth price X keys
functionhash 0xcf808000
param keys number keys desired ( 18 decimal format )
return amount eth needed send
dev receives name player info names contract
dev receives entire player name list
dev gets existing registers new p ID use player may new
return p ID
dev decides round end needs run & new round started
player unmasked earnings previously played rounds need moved
dev ends round manages paying winner splitting pot
dev moves unmasked earnings gen vault updates earnings mask
dev updates round timer based number whole keys bought
dev distributes eth based fees , aff , pooh
dev distributes eth based fees gen pot
dev updates masks round player keys bought
return dust left
MASKING NOTES
earnings masks tricky thing people wrap minds around
basic thing understand going global
tracker based profit per share round , increases
relevant proportion increase share supply
player additional mask basically says "based
rounds mask , shares , much i've already withdrawn ,
much still owed ? "
dev adds unmasked earnings , & vault earnings , sets 0
return earnings wei format
dev prepares compression data fires event buy reload tx's
upon contract deploy , deactivated one time
use function activate contract devs
time set things web end
Upon game death , might ETH still locked contract
one time use function empty contract
send eth POOH tokenholders
dev calculates number keys received given X eth
param cur Eth current amount eth contract
param new Eth eth spent
return amount ticket purchased
dev calculates amount eth received sold X keys
param cur Keys current amount keys exist
param sell Keys amount keys wish sell
return amount eth received
dev calculates many keys would exist given amount eth
param eth eth "in contract"
return number keys would exist
dev calculates much eth would contract given number keys
param keys number keys "in contract"
return eth would exists
dev filters name strings
converts uppercase lower case
makes sure start end space
makes sure contain multiple spaces row
cannot numbers
cannot start 0x
restricts characters Z , z , 0 9 , space
return reprocessed string bytes32 format
title Safe Math v0 1 9
dev Math operations safety checks throw error
change notes : original Safe Math library Open Zeppelin modified Inventor
added sqrt
added sq
added pwr
changed asserts requires error log outputs
removed div , useless
dev Multiplies two numbers , throws overflow
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
dev gives square root given x
dev gives square multiplies x x
dev x power
fired whenever player registers name
fired end buy reload
fired whenever theres withdraw
fired whenever withdraw forces end round ran
fired whenever player tries buy round timer
hit zero , causes end round ran
fired whenever player tries reload round timer
hit zero , causes end round ran
fired whenever affiliate paid
received pot swap deposit
( ( ) | |~|~| ( || || ( || ) | ( \ ( game settings )
length first ICO phase
length ICO phases
round timer starts
max length round timer ( first round )
every full key purchased adds much timer
( | ( | | ( | \ ( | | || ) ( data used store game info changes )
round id number total rounds happened
PLAYER DATA
( addr = p ID ) returns player id address
( name = p ID ) returns player id name
( p ID = data ) player data
( p ID = r ID = data ) player round data player id & round id
( p ID = name = bool ) list names player owns ( used change display name amongst name )
ROUND DATA
( r ID = data ) round data
( r ID = ID = data ) eth per team , round id team id
TEAM FEE DATA
( team = fees ) fee distribution team
( team = fees ) pot split distribution team
( ( ) | | \ | | | | ( | ( ) | ( initial data setup upon contract deploy )
teams POOH heads
Referrals Community rewards mathematically designed come winner's share pot
30% pot , 10% aff , 1% dev ,
36% winner , 36% next round , 3% dev
| | | ( ) ( ||~|~| ( | \ ( safety checks )
| ) | || ) || ( ~|~| || | ( | | ( ) | | \ ( use interact contract )
set tx event data determine player new
fetch player id
buy core
set tx event data determine player new
fetch player id
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given & previously stored
update last affiliate
buy core
set tx event data determine player new
fetch player id
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given
get affiliate ID aff Code
aff ID previously stored
update last affiliate
buy core
set tx event data determine player new
fetch player id
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given
get affiliate ID aff Code
aff ID previously stored
update last affiliate
buy core
set tx event data
fetch player ID
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given & previously stored
update last affiliate
reload core
set tx event data
fetch player ID
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given
get affiliate ID aff Code
aff ID previously stored
update last affiliate
reload core
set tx event data
fetch player ID
manage affiliate residuals
affiliate code given player tried use , lolz
use last stored affiliate code
affiliate code given
get affiliate ID aff Code
aff ID previously stored
update last affiliate
reload core
setup local r ID
grab time
fetch player ID
setup temp var player eth
check see round ended one run round end yet
set tx event data
end round ( distributes pot )
get earnings
gib moni
build event data
fire withdraw distribute event
situation
get earnings
gib moni
fire withdraw event
fire event
fire event
fire event
( | ( | | ( | \ ( UI & viewing things etherscan )
setup local r ID
grab time
setup local r ID
round ended round end run ( contract distributed winnings )
player winner
player winner
round still going , round ended round end ran
setup local r ID
setup local r ID
( ( ) | ( | ( ) ( || ( ( + tools + calcs + modules = softwares engine )
setup local r ID
grab time
round active
call core
round active
check see end round needs ran
end round ( distributes pot ) & start new round
build event data
fire buy distribute event
put eth players vault
setup local r ID
grab time
round active
get earnings vaults return unused gen vault
use custom safemath library throw player
tried spend eth
call core
round active end round needs ran
end round ( distributes pot ) & start new round
build event data
fire buy distribute event
player new round
early round eth limiter
( round [ r ID] eth 100000000000000000000 && plyr Rnds [ p ID][ r ID] eth add ( eth ) 5000000000000000000 )
uint256 available Limit = ( 5000000000000000000 ) sub ( plyr Rnds [ p ID][ r ID] eth ) ;
uint256 refund = eth sub ( available Limit ) ;
plyr [ p ID] gen = plyr [ p ID] gen add ( refund ) ;
eth = available Limit;
eth left greater min eth allowed ( sorry pocket lint )
mint new keys
bought least 1 whole key
set new leaders
set new leader bool true
update player
update round
distribute eth
call end tx function fire end tx event
grab time
round ?
rounds need keys new round
setup local r ID
grab time
round ?
rounds need price new round
player new version fomo3d
grab player ID , name last aff ID , player names contract
set player account
set new player bool true
player played previous round , move unmasked earnings
round gen vault
update player's last round played
set joined round bool true
setup local r ID
grab winning player team id's
grab pot amount
calculate winner share , community rewards , gen share ,
p3d share , amount reserved next pot
calculate ppt round mask
pay winner
community rewards
distribute gen portion key holders
prepare event data
start next round
put gen vault
zero earnings updating mask
grab time
calculate time based number keys bought
compare max set new end time
pay 1% dev
distribute share affiliate
decide affiliate share fees
affiliate must self , must name registered
pay POOH
set event data
using method
calculate gen share
update eth balance ( eth = eth ( share + pot swap share + aff share + p3d share + airdrop pot share ) )
calculate pot
distribute gen share ( thats update Masks ( ) ) adjust
balances dust
add eth pot
set event data
calc profit per key & round mask based buy : ( dust goes pot )
calculate player earning buy ( based keys
bought ) & update player earnings mask
calculate & return dust
update gen vault
vaults
team activate
ran
activate contract
lets start first round
team activate
take black holed eth left contract send pooh whale
winner address
winner name
amount
amount new pot
amount distributed p3d
amount distributed gen
amount added pot
player address
player name
winnings vault
general vault
affiliate vault
last round played
last affiliate id used
eth player added round ( used eth limiter )
keys
player mask
ICO phase investment
p ID player lead
ID team lead
time ends ended
round end function ran
time round started
keys
total eth
eth pot ( round ) final amount paid winner ( round ends )
global mask
total eth sent ICO phase
total eth gen ICO phase
average key price ICO phase
% buy thats paid key holders current round
% buy thats paid POOH holders
% pot thats paid key holders current round
% pot thats paid POOH holders
return ( ( ( ( ( ( eth ) mul ( 1000000000000000000 ) ) mul ( 200000000000000000000000000000000 ) ) add ( 2500000000000000000000000000000000000000000000000000000000000000 ) ) sqrt ( ) ) sub ( 50000000000000000000000000000000 ) ) ( 100000000000000 ) ;
return ( ( 50000000000000 ) mul ( keys sq ( ) ) add ( ( ( 100000000000000 ) mul ( keys mul ( 1000000000000000000 ) ) ) ( 2 ) ) ) ( ( 1000000000000000000 ) sq ( ) ) ;
sorry limited 32 characters
make sure doesnt start end space
make sure first two characters 0x
create bool track non number character
convert & check
uppercase Z
convert lower case z
non number
require character space
lowercase z
make sure theres 2x spaces row
see character number

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Safe ERC20
dev Wrappers around ERC20 operations throw failure
use library add `using Safe ERC20 ERC20;` statement contract ,
allows call safe operations `token safe Transfer ( ) ` , etc
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Contracts able recover tokens
Syl Ti
dev allow contract recover ERC20 token received contract transferring balance contract owner
prevent accidental loss tokens
dev Reclaim ERC20Basic compatible tokens
param token ERC20Basic address token contract
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
title Pausable
dev Base contract allows children implement emergency stop mechanism
dev Modifier make function callable contract paused
dev Modifier make function callable contract paused
dev called owner pause , triggers stopped state
dev called owner unpause , returns normal state
title Pausable token
dev Standard Token modified pausable transfers
title ERC827 interface , extension ERC20 token standard
Interface ERC827 token , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
title ERC827 , extension ERC20 token standard
Implementation ERC827 , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
Uses Open Zeppelin Standard Token
dev Addition ERC20 token methods allows
approve transfer value execute call sent data
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race condition
first reduce spender's allowance 0 set desired value
afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens specified
address execute call sent data transaction
param address address want transfer
param value uint256 amout tokens transfered
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens one address
another make contract call transaction
param address want send tokens
param address want transfer
param value amout tokens transferred
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition Standard Token methods Increase amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
param data ABI encoded contract call call ` spender` address
dev Addition Standard Token methods Decrease amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
param data ABI encoded contract call call ` spender` address
title Crowdsale
dev Crowdsale base contract managing token crowdsale ,
allowing investors purchase tokens ether contract implements
functionality fundamental form extended provide additional
functionality custom behavior
external interface represents basic interface purchasing tokens , conform
base architecture crowdsales *not* intended modified overriden
internal interface conforms extensible modifiable surface crowdsales Override
methods add functionality Consider using 'super' appropiate concatenate
behavior
Event token purchase logging
param purchaser paid tokens
param beneficiary got tokens
param value weis paid purchase
param amount amount tokens purchased
param rate Number token units buyer gets per wei
param wallet Address collected funds forwarded
param token Address token sold
dev fallback function ***DO OVERRIDE
dev low level token purchase ***DO OVERRIDE
param beneficiary Address performing token purchase
dev Validation incoming purchase Use require statemens revert state conditions met Use super concatenate validations
param beneficiary Address performing token purchase
param wei Amount Value wei involved purchase
dev Source tokens Override method modify way crowdsale ultimately gets sends tokens
param beneficiary Address performing token purchase
param token Amount Number tokens emitted
dev Executed purchase validated ready executed necessarily emits sends tokens
param beneficiary Address receiving tokens
param token Amount Number tokens purchased
dev Override extend way ether converted tokens
param wei Amount Value wei converted tokens
return Number tokens purchased specified wei Amount
dev Determines ETH stored forwarded purchases
title Staged Crowdsale
title Refund Vault
dev contract used storing funds crowdsale
progress Supports refunding money crowdsale fails ,
forwarding crowdsale successful
param wallet Vault address
param investor Investor address
param investor Investor address
title Minted Crowdsale
dev Extension Crowdsale contract whose tokens minted purchase
Token ownership transferred Minted Crowdsale minting
dev Overrides delivery minting tokens upon purchase
param beneficiary Token purchaser
param token Amount Number tokens minted
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : zeppelin solidity contracts token ERC20 Safe ERC20 sol
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Reclaim Token sol
File : zeppelin solidity contracts math Safe Math sol
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
File : zeppelin solidity contracts token ERC20 Basic Token sol
Safe Math sub throw enough balance
File : zeppelin solidity contracts token ERC20 Standard Token sol
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
File : zeppelin solidity contracts token ERC20 Mintable Token sol
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
File : zeppelin solidity contracts lifecycle Pausable sol
File : zeppelin solidity contracts token ERC20 Pausable Token sol
File : zeppelin solidity contracts token ERC827 ERC827 sol
File : zeppelin solidity contracts token ERC827 ERC827Token sol
github ethereum EIPs issues 20 issuecomment 263524729
File : contracts Pallium Token sol
File : zeppelin solidity contracts crowdsale Crowdsale sol
token sold
Address funds collected
many token units buyer gets per wei
Amount wei raised
Crowdsale external interface
calculate token amount created
update state
Internal interface ( extensible )
optional override
optional override
File : contracts Staged Crowdsale sol
File : zeppelin solidity contracts crowdsale distribution utils Refund Vault sol
File : contracts Staged Refund Vault sol
File : zeppelin solidity contracts crowdsale emission Minted Crowdsale sol
File : contracts Pallium Crowdsale sol
25 000 000 PLMT team token pool
used previous stage reach soft Cap ,
refaund available next stage begins

dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
dev Burns specific amount tokens
param value amount token burned
Variables old token contract
Public variables token ERC20 compliance
Public variables specific Peculium
Event freeze account
Public Functions contract
Owner Functions contract
Others Functions contract
Approves calls receiving contract
Public variables token ERC20 compliance
Public variables specific Peculium
Event freeze account
Public Functions contract
Owner Functions contract
Others Functions contract
Approves calls receiving contract
Safe Math sub throw enough balance
token Peculium
address old Peculium contract
decimal token
Constructor
first test enough token send
enough token , cancel send
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
token standard ERC20 Token burnable ownable aptitude
old Peculium token
address old Peculium contract
use safemath basic math operation ( + , , * , )
token name
token symbol
token number decimal
max cap 20 Billion Peculium
boolean variable , frost tokens
Constructor
beginning , contract tokens
overright transfer function allow freeze possibility
overright transfer function allow freeze possibility
Use function swap old peculium new ones ( new ones need defrost transfered )
Old peculium burned
Return info public address balance account owner contract
token standard ERC20 Token burnable ownable aptitude
use safemath basic math operation ( + , , * , )
token name
token symbol
token number decimal
max cap 20 Billion Peculium
date deployment token
boolean variable , frost tokens
date owners token defrost tokens
Constructor
beginning , owner tokens
owner need sell token private sale pre ICO , ICO
everybody defrost token 25 january 2018 ( 85 days 1 November )
Function defrost token , date defrost
overright transfer function allow freeze possibility
overright transfer function allow freeze possibility ( need allow )
Return info public address balance account owner contract

Bonus part :
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Fix ERC20 short address attack
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
Date start pre ICO ICO
start Saturday , March 31 , 2018 12 : 00 : 00
end Sunday , April 15 , 2018 12 : 00 : 00
start Tuesday , May 22 , 2018 12 : 00 : 00
end Wednesday , May 23 , 2018 12 : 00 : 00
max minting ( 108 , 000 , 000 tokens )
bounty amount ( 32 , 400 , 000 tokens )
max number tokens pre ICO ( 8 , 100 , 000 tokens ) ;
Amount bonuses
pre ICO bonuses time
ICO bonuses time
rate ether , much tokens gives 1 ether
require ( current Time ( ) pre ICOstart Time ) ;
add BTC

data
Handle roundoff last contributor

Version : C
Pratyush Bhatt [email protected]
Overview :
Divides incoming funds among various `activity` accounts division cannot changed
contract locked
total funds credited account
current balance = credited amount withdrawn
percent allocation times ten
payout addr acct
need gt 1000 wei distribute
max accounts contract handle
deployer executor
accounts index
many activity accounts
amount received since begin time
amount distributed since begin time
amount withdrawn since begin time
gas withdrawals
constructor
reset
reset activity accounts
case funds withdrawn , become newly received undistributed
set withdrawal gas
nonstandard gas necessary support push withdrawals contract
add new activity account
get acct info
get total percentages x10
default payable function
call us plenty gas , catastrophe ensue
distribute funds activities
payout 1000 wei
account gets prescribed percentage holdover
also double check ensure amount credited cannot exceed total amount due acct
withdraw actvity balance
called owner push funds another contract
put back funds case err
suicide

2 PM
40% ethers unvested
Owner
Auctus Ether Vesting SC
Auctus core team 20%
Bounty 2%
Reserve Future 18%
Partnerships Advisory free amount 1 8%
Partnerships Advisory vested amount 7 2%
Auctus Token Vesting SC
Auctus Bounty Distribution SC
Auctus Token Vesting SC
Auctus Pre Sale Distribution SC
Auctus Token Vesting SC

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Pausable
dev Base contract allows children implement emergency stop mechanism
dev Modifier make function callable contract paused
dev Modifier make function callable contract paused
dev called owner pause , triggers stopped state
dev called owner unpause , returns normal state
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title ERC827 interface , extension ERC20 token standard
Interface ERC827 token , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title ERC827 , extension ERC20 token standard
Implementation ERC827 , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
Uses Open Zeppelin Standard Token
dev Addition ERC20 token methods allows
approve transfer value execute call sent data
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race condition
first reduce spender's allowance 0 set desired value
afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens specified
address execute call sent data transaction
param address address want transfer
param value uint256 amout tokens transfered
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens one address
another make contract call transaction
param address want send tokens
param address want transfer
param value amout tokens transferred
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition Standard Token methods Increase amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
param data ABI encoded contract call call ` spender` address
dev Addition Standard Token methods Decrease amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
param data ABI encoded contract call call ` spender` address
title JOYToken
dev simple ERC20 Token example , tokens pre assigned creator
Note later distribute tokens wish using `transfer`
`Standard Token` functions
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
github ethereum EIPs issues 20 issuecomment 263524729
@dev sell token
@dev Remove fees contract
using boolean method make sure even one fails still work
@dev buy token

title Contract Receiver
dev Receiver ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
dev Prevent targets sending receiving tokens
param targets Addresses frozen
param Frozen either freeze
dev Prevent targets sending receiving tokens setting Unix times
param targets Addresses locked funds
param unix Times Unix times locking finished
dev Burns specific amount tokens
param address burn tokens
param unit Amount amount token burned
dev Function mint tokens
param address receive minted tokens
param unit Amount amount tokens mint
dev Function stop minting new tokens
dev Function distribute tokens list addresses provided amount
dev Function collect tokens list addresses
dev Function distribute tokens msg sender automatically
distribute Amount 0 , function work
dev token fallback function
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

2 PM
40% ethers unvested
Owner
Auctus Ether Vesting SC
Auctus core team 20%
Bounty 2%
Reserve Future 18%
Partnerships Advisory free amount 1 8%
Partnerships Advisory vested amount 7 2%
Auctus Token Vesting SC
Auctus Bounty Distribution SC
Auctus Token Vesting SC
Auctus Pre Sale Distribution SC
Auctus Token Vesting SC

Implements ERC 20 standard
Added support ERC 223

title Manager
H Kang
FUNCTION
MODIFIER
title Ethername Raw
H Kang
EVENT
DATA STRUCT
STORAGE
FUNCTION
VIEW FUNCTION
INTERNAL FUNCTION
dev transferred ,
price approved set 0 attrs remains
MODIFIER
title Ethername
H Kang
notice contract designed DAPPs
username feature without additional implementation
CONSTRUCTOR
FUNCTION
VIEW FUNCTION
reserved word
initial register

dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
dev Standard ERC223 function handle incoming token transfers
param Token sender address
param value Amount tokens
param data Transaction metadata
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
dev Transfer specified amount tokens specified address
Invokes `token Fallback` function recipient contract
token transfer fails recipient contract
implement `token Fallback` function
param Receiver address
param value Amount tokens transferred
param data Transaction metadata
dev Transfer specified amount tokens specified address
Invokes ` custom fallback` function recipient contract
token transfer fails recipient contract
implement ` custom fallback` function
param Receiver address
param value Amount tokens transferred
param data Transaction metadata
solium disable next line
dev Transfer specified amount tokens specified address
Added due backwards compatibility reasons
param Receiver address
param value Amount tokens transferred
dev Retrieve size code target address , needs assembly
param addr address check contract
return contract TRUE contract else false
solium disable next line
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
github ethereum EIPs issues 20 issuecomment 263524729
25 million

title ERC827 interface , extension ERC20 token standard
Interface ERC827 token , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title ERC827 , extension ERC20 token standard
Implementation ERC827 , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
Uses Open Zeppelin Standard Token
dev Addition ERC20 token methods allows
approve transfer value execute call sent data
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race condition
first reduce spender's allowance 0 set desired value
afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens specified
address execute call sent data transaction
param address address want transfer
param value uint256 amout tokens transfered
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens one address
another make contract call transaction
param address want send tokens
param address want transfer
param value amout tokens transferred
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition Standard Token methods Increase amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
param data ABI encoded contract call call ` spender` address
dev Addition Standard Token methods Decrease amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
param data ABI encoded contract call call ` spender` address
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Pausable
dev Base contract allows children implement emergency stop mechanism
dev Modifier make function callable contract paused
dev Modifier make function callable contract paused
dev called owner pause , triggers stopped state
dev called owner unpause , returns normal state
title Burnable Token
dev Token irreversibly burned ( destroyed )
dev Burns specific amount tokens
param value amount token burned
title Pausable token
dev Standard Token modified pausable transfers
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
dev Constructor gives msg sender existing tokens
github ethereum EIPs issues 179
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
solium disable line uppercase
solium disable line uppercase
solium disable line uppercase

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
Interface standard token
Based https : github ethereum EIPs blob master EIPS eip 20 token standard md
github ethereum EIPs blob master EIPS eip 20 token standard md
owner contract externally owned account
Address target contract
Major partner address
Minor partner address
Additional gas used transfers
Payments contract require bit gas 100k enough
Transfer funds target investment address
Major fee 0 3 10 5
Minor fee 0 2 10 5
Send rest
Sets amount additional gas allowed addresses called
@dev allows transfers multisigs use 2300 gas fallback function
use function move unwanted tokens contract
contract designed balance
However , include function avoid stuck value unknown mishap

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Pausable
dev Base contract allows children implement emergency stop mechanism
dev Modifier make function callable contract paused
dev Modifier make function callable contract paused
dev called owner pause , triggers stopped state
dev called owner unpause , returns normal state
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title ERC827 interface , extension ERC20 token standard
Interface ERC827 token , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
title ERC827 , extension ERC20 token standard
Implementation ERC827 , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
Uses Open Zeppelin Standard Token
dev Addition ERC20 token methods allows
approve transfer value execute call sent data
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race condition
first reduce spender's allowance 0 set desired value
afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens specified
address execute call sent data transaction
param address address want transfer
param value uint256 amout tokens transfered
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens one address
another make contract call transaction
param address want send tokens
param address want transfer
param value amout tokens transferred
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition Standard Token methods Increase amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
param data ABI encoded contract call call ` spender` address
dev Addition Standard Token methods Decrease amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
param data ABI encoded contract call call ` spender` address
title Pausable token
dev ERC827Token modified pausable transfers
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
title Capped token
dev Mintable token token cap
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
SZ : Change collection address deploy
SZ : price1 3 AIRX per 1 ETH
SZ : lev1 2 ETH
SZ : AIRX constructor Hard Cap AIRX tokens
SZ : Functions set Lev1 , set Lev2 change levels prices
SZ : lev1 2 send example "2000000000000000000" 2 ETH
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
github ethereum EIPs issues 20 issuecomment 263524729
ERC20
ERC827
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol

Ethernity Financial Oracle v0 2
@ethernity live
Main constructor
0xfb509f6900d0326520c8f88e8f12c83459a199ec;
Payable receive payments stores mapping modifier
REQUESTS
GETTERS
avoid overflow exploitation
SET RESPONSE ORACLE
Callback function : passive , expensive , somewhat private
Mapping : active , cheap , public
INTERNAL FUNCTIONS
ADMIN FUNCTIONS

Events
Storage
Public functions
Internal functions
Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
Events
Storage
Public functions
Internal functions
Web3 call functions
Public functions
@dev Returns number instantiations creator
@param creator Contract creator
@return Returns number instantiations creator
@dev Registers contract factory registry
@param instantiation Address contract instantiation
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George [email protected]
@dev Contract constructor sets initial owners , required number confirmations daily withdraw limit
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount
@title Multisignature wallet factory daily limit version Allows creation multisig wallet
@ Stefan George [email protected]
@dev Allows verified creation multisignature wallet
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@return Returns wallet address

Copyright ( c ) 2015 2016 Oraclize SRL
Copyright ( c ) 2016 Oraclize LTD
Permission hereby granted , free charge , person obtaining copy
software associated documentation files ( "Software" ) , deal
Software without restriction , including without limitation rights
use , copy , modify , merge , publish , distribute , sublicense , sell
copies Software , permit persons Software
furnished , subject following conditions :
copyright notice permission notice shall included
copies substantial portions Software
SOFTWARE PROVIDED "AS IS" , WITHOUT WARRANTY KIND , EXPRESS
IMPLIED , INCLUDING LIMITED WARRANTIES MERCHANTABILITY ,
FITNESS PARTICULAR PURPOSE NONINFRINGEMENT EVENT SHALL
AUTHORS COPYRIGHT HOLDERS LIABLE CLAIM , DAMAGES
LIABILITY , WHETHER ACTION CONTRACT , TORT OTHERWISE , ARISING ,
CONNECTION SOFTWARE USE DEALINGS
SOFTWARE
title String & slice utility library Solidity contracts
Nick Johnson [email protected]
dev Functionality library largely implemented using
abstraction called 'slice' slice represents part string
anything entire string single character , even
characters ( 0 length slice ) Since slice specify
offset length , copying manipulating slices lot less
expensive copying manipulating strings reference
reduce gas costs , functions slice need return
slice modify original one instead allocating new one;
instance , `s split ( " " ) ` return text first ' ' ,
modifying contain remainder string ' '
situations want modify original slice ,
make copy first ` copy ( ) ` , example :
`s copy ( ) split ( " " ) ` Try avoid using idiom loops; since
Solidity memory management , result allocating many
short lived slices later discarded
Functions return two slices come two versions : non allocating
version takes second slice argument , modifying
place , allocating version allocates returns second
slice; see `next Rune` example
Functions copy string data return strings rather
slices; cast back slices processing
required
convenience , functions provided non modifying
variants create new slice return both; instance ,
`s split New ( ' ' ) ` leaves unmodified , returns two values
corresponding left right parts string
dev Returns slice containing entire string
param self string make slice
return newly allocated slice containing entire string
dev Returns length null terminated bytes32 string
param self value find length
return length string , 0 32
dev Returns slice containing entire bytes32 , interpreted
null termintaed utf 8 string
param self bytes32 value convert slice
return new slice containing value input argument
first null
dev Returns new slice containing data current slice
param self slice copy
return new slice containing data `self`
dev Copies slice new string
param self slice copy
return newly allocated string containing slice's text
dev Returns length runes slice Note operation
takes time proportional length slice; avoid using
loops , call `slice empty ( ) ` need know whether
slice empty
param self slice operate
return length slice runes
dev Returns true slice empty ( length 0 )
param self slice operate
return True slice empty , False otherwise
dev Returns positive number `other` comes lexicographically
`self` , negative number comes , zero
contents two slices equal Comparison done per rune ,
unicode codepoints
param self first slice compare
param second slice compare
return result comparison
dev Returns true two slices contain text
param self first slice compare
param self second slice compare
return True slices equal , false otherwise
dev Extracts first rune slice `rune` , advancing
slice point next rune returning `self`
param self slice operate
param rune slice contain first rune
return `rune`
dev Returns first rune slice , advancing slice point
next rune
param self slice operate
return slice containing first rune `self`
dev Returns number first codepoint slice
param self slice operate
return number first codepoint slice
dev Returns keccak 256 hash slice
param self slice hash
return hash slice
dev Returns true `self` starts `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` starts `needle` , `needle` removed
beginning `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Returns true slice ends `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` ends `needle` , `needle` removed
end `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Modifies `self` contain everything first occurrence
`needle` end slice `self` set empty slice
`needle` found
param self slice search modify
param needle text search
return `self`
dev Modifies `self` contain part string start
`self` end first occurrence `needle` `needle`
found , `self` set empty slice
param self slice search modify
param needle text search
return `self`
dev Splits slice , setting `self` everything first
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything first
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` first occurrence `delim`
dev Splits slice , setting `self` everything last
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything last
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` last occurrence `delim`
dev Counts number nonoverlapping occurrences `needle` `self`
param self slice search
param needle text search `self`
return number occurrences `needle` found `self`
dev Returns True `self` contains `needle`
param self slice search
param needle text search `self`
return True `needle` found `self` , false otherwise
dev Returns newly allocated string containing concatenation
`self` `other`
param self first slice concatenate
param second slice concatenate
return concatenation two strings
dev Joins array slices , using `self` delimiter , returning
newly allocated string
param self delimiter use
param parts list slices join
return newly allocated string containing slices `parts` ,
joined `self`
init
use TLSNotary oraclize call
init min bet ( 0 1 ether )
init gas oraclize
init gas price callback ( default 20 gwei )
init caissa state
ORACLIZE API
mainnet
ropsten testnet
kovan testnet
rinkeby testnet
ethereum bridge
ether camp ide
browser solidity
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
parse Int
parse Int ( parse Float*10^ b )
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
Step 6 : verify attestation signature , APPKEY1 must sign session Key correct ledger app ( CODEHASH )
role
Step 7 : verify APPKEY1 provenance ( must signed Ledger )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 2 : unique keyhash match sha256 ( context name + query Id )
Step 3 : assume sig1 valid ( verified step 5 ) verify 'result' prefix sha256 ( sig1 )
Step 4 : commitment match verification , sha3 ( delay , nbytes , unonce , session Key Hash ) == commitment storage
verify computed args match ones specified query
unonce , nbytes session Key Hash match
Step 5 : validity verification sig1 ( keyhash args signed session Key )
verify session Pubkey Hash verified already , let's !
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Buffer small
better way ?
NOTE : offset 32 added skip `size` field bytes variables
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Duplicate Solidity's ecrecover , catching CALL return value
memory management Solidity uses memory offset
0x40 store current end memory write past (
writes memory extensions ) , update offset
Solidity reuse memory used needed
context
FIXME : inline assembly can't access return values
NOTE : reuse request memory deal
return code
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
signature format compact form :
{bytes32 r}{bytes32 s}{uint8 v}
Compact means , uint8 padded 32 bytes
loading last 32 bytes exploit fact
'mload' pad zeroes overread
'mload8' , would nicer
Alternative solution :
'byte' working due Solidity parser , lets
use second best option , 'and'
v : = ( mload ( add ( sig , 65 ) ) , 255 )
albeit non transactional signatures specified YP , one would expect
match YP range [27 , 28]
geth uses [0 , 1] clients followed might change , see :
https : github ethereum go ethereum issues 2053
ORACLIZE API
Copy word length chunks possible
Copy remaining bytes
Allocate space `self` memory , copy , point ret
Starting ptr 31 means LSB byte care
Mask irrelevant bytes check
Load first byte rune LSBs b
Check truncated codepoints
Load rune MSBs b
Check truncated codepoints
Invalid UTF 8 sequence
Returns memory address first byte first occurrence
`needle` `self` , first byte `self` found
Optimized assembly 68 gas per byte short strings
long needles , use hashing
Returns memory address first byte last occurrence
`needle` `self` , address `self` found
Optimized assembly 69 gas per byte short strings
long needles , use hashing
found
found
randseed org api randintwithseed ? min=1&apikey=w Sxw2ss Jd Sdf D3320S&seed=";

! iam sol | ( c ) 2018 Develop Belov ITLab LLC ( smartcontract ru ) , @stupidlovejoy | License : MIT
ICO IAM

ERC20 contract interface
ERC23 ERC223 Extensions
Fully backward compatible ERC20
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
Include Safe Math Lib
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
EDOGE ERC20 token ERC223 Extensions
github Dexaran ERC223 token standard tree Recommended *
ERC223 ERC20 functions events
ERC223 functions
ERC20 functions events
Security check case EVM future flaw exploit call constructor multiple times
Ensure token gets created
Final sanity check ensure owner balance greater zero
Function access name token sha
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract
Get balance address provided
Allow transfers owner provided allowance
Prevent transfers token yet unlocked
Use Safe Math main logic
Protect wrapping uints

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
Observer contract
Crowdsale contract
Manager stores permitted addresses
title Building Object contract
Vladimir Kovalchuk
Name object
Gross building area
Gress sale area
Parking space
Type building
Developer object
Leed
Location object
start date project
end construction object
report completion
ERC223 Unity token
Hold contract
Permission manager contract
Constructor object
Public setters area
unt sqm

Internal functions
Web3 call functions
one creates contract , person set token
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
TGE SETTINGS
@dev Sends request change settings
@return Transaction ID
asserting parameter zero except part Founders
@dev Allows owner confirm change settings request
@param tx Index Transaction ID
@dev Shows settings requested settings change request
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Original code smart contract github :
Standart libary "Open Zeppelin"
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Standart contract "Open Zeppelin"
Standart contract "Open Zeppelin"
Describing contract owner
Describing Bloccking modifier founds time block
Time till modifier block
contract discribes contract token founds ERC20 implement balance function
! array balances
Contract dividend tokens contract describes implementation tokens used dividends
Event dividends somebody takes dividends raised
mapping alloweds amounts
full reward amount one round
value defined ether amount Dividend Token contract moment dividend payments starts
time last time dividends started pay
Fix ERC20 short address attack
modifier checkes reward payment
Structure Token holder contains information token holders balances times
mapping token holders
number days rewards
standard method transfer ERC20
internal implementation transfer recounting rewards
standard method transfer ERC20
standard method transfer ERC20
standard method transfer ERC20
method returns amount caller's reward
Caller gets ether given
method shoud called caller wants take dividends reward
Caller gets ether given
garbage collector
Divide reward make accesible withdraw
Need provide number days reward less 15 days 45 days
Take left reward reward period
recount reward somebody
Final contract RENT coin
Uses overwork manual Blocked contract ICO time
ICO needed

@title Lianzhiliao
token 18 digit precision
1 Billion Tokens
pd : prod , tk : token Amount , et : ether Amount
@notice Initializes contract allocates initial tokens owner agreement account
100 percent goes owner
accept ethers payable modifier
@notice transfer token contract ownership
@param new Owner address new owner contract
Owner transfer ERC20 tokens sent mistake

Digital Fantasy Sports digital sports platform brings concept playing fantasy sports
using cryptocurrencies extraordinary fantasy players created ER20 token called
DFS provides simple secure interface players league action
love featuring multiple gaming sport platforms use DFS game currency
Website : https : www digitalfantasysports
Twitter : https : twitter dfstoken
Reddit : https : www reddit r dfstoken
Discord : https : discordapp channels 397817936884269057 397817937731387403
Bitcoin Talk : https : bitcointalk org index php ? topic=2223626 0
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title ERC827 interface , extension ERC20 token standard
Interface ERC827 token , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
title Safe ERC20
dev Wrappers around ERC20 operations throw failure
use library add `using Safe ERC20 ERC20;` statement contract ,
allows call safe operations `token safe Transfer ( ) ` , etc
title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Contracts Ether
Remco Bloemen [email protected]π
dev tries block incoming ether prevent accidental loss Ether Ether end
contract , allow owner reclaim ether
notice Ether still send contract :
calling functions labeled `payable`
`selfdestruct ( contract address ) `
mining directly contract address
dev Constructor rejects incoming Ether
dev `payable` flag added access `msg value` without compiler warning
leave payable , Solidity allow inheriting contracts implement payable
constructor way prevent payable constructor working Alternatively
could use assembly access msg value
dev Disallows direct send settings default function without `payable` flag
dev Transfer Ether held contract owner
title Contracts Contracts
Remco Bloemen [email protected]π
dev contracts ( anything Ownable ) end owned contract , allows owner
contract reclaim ownership contracts
dev Reclaim ownership Ownable contracts
param contract Addr address Ownable reclaimed
title Contracts able recover tokens
Syl Ti
dev allow contract recover ERC20 token received contract transferring balance contract owner
prevent accidental loss tokens
dev Reclaim ERC20Basic compatible tokens
param token ERC20Basic address token contract
title Contracts Tokens
Remco Bloemen [email protected]π
dev blocks incoming ERC23 tokens prevent accidental loss tokens
tokens ( ERC20Basic compatible ) end contract , allows
owner reclaim tokens
dev Reject ERC23 compatible tokens
param address address transferring tokens
param value uint256 amount specified token
param data Bytes data passed caller
title Base contract contracts things
Remco Bloemen [email protected]π
dev Solves class errors contract accidentally becomes owner Ether , Tokens
Owned contracts See respective base contracts details
title Basic token
dev Basic version Standard Token , allowances
dev total number tokens existence
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Increase amount tokens owner allowed spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
title ERC827 , extension ERC20 token standard
Implementation ERC827 , following ERC20 standard extra
methods transfer value data execute calls transfers
approvals
Uses Open Zeppelin Standard Token
dev Addition ERC20 token methods allows
approve transfer value execute call sent data
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race condition
first reduce spender's allowance 0 set desired value
afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens specified
address execute call sent data transaction
param address address want transfer
param value uint256 amout tokens transfered
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition ERC20 token methods Transfer tokens one address
another make contract call transaction
param address want send tokens
param address want transfer
param value amout tokens transferred
param data ABI encoded contract call call ` to` address
return true call function executed successfully
dev Addition Standard Token methods Increase amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param added Value amount tokens increase allowance
param data ABI encoded contract call call ` spender` address
dev Addition Standard Token methods Decrease amount tokens
owner allowed spender execute call sent data
approve called allowed[ spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
param spender address spend funds
param subtracted Value amount tokens decrease allowance
param data ABI encoded contract call call ` spender` address
www digitalfantasysports
twitter dfstoken
www reddit r dfstoken
discordapp channels 397817936884269057 397817937731387403
bitcointalk org index php ? topic=2223626 0
= = Open Zeppelin library = =
github ethereum EIPs issues 179
github ethereum EIPs issues 20
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
github ethereum EIPs issues 20 issuecomment 263524729
= = DFS Contracts = =
allows dissable transfers minting case emergency

= =ERC721 interface= =
= =Forever Rose= =
= =Multi Sig Wallet= =
Public functions
Internal functions
Web3 call functions
function withdraw GTO ( address , uint256 balance ) Owner internal {
require ( Gifto balance ( address ( ) ) = balance ) ;
Gifto transfer ( , balance ) ;
Transfer IAMI outside account
function withdraw IAMI ( address , uint256 balance ) Owner internal {
require ( IAMIToken balance ( address ( ) ) = balance ) ;
IAMIToken transfer ( , balance ) ;
Change Gifto contract's address another type token , like Ether
function set IAMIToken Address ( address new Address ) public Owner {
IAMIToken = ERC20 ( new Address ) ;
function set Gifto Address ( address new Address ) public Owner {
Gifto = ERC20 ( new Address ) ;
@title Interface contracts conforming ERC 721 : Non Fungible Tokens
@ Yumin yang
Required methods
function owner ( uint256 token Id ) external view returns ( address owner ) ;
function approve ( address , uint256 token Id ) external;
function transfer ( address , address , uint256 token Id ) external;
Events
event Approval ( address owner , address approved , uint256 token Id ) ;
@title Interface contracts conforming ERC 721 : Non Fungible Tokens
@ Yumin yang
contract's owner
Gift token storage
Total supply token
Divisibility ownership token
much owners token
Forever Rose created
Special gift token
@dev Constructor
Create Forever rose
Fallback funciton
use parameter ' token Id' divisibility
Requiring contract tradable
Take token Id divisibility
Requiring msg sender Holdings Forever rose
Remove divisibilitys old owner
Add divisibilitys new owner
Trigger Ethereum Event
Transfer gift new owner
Requiring msg sender Holdings Forever rose
Remove ownership old Owner ( msg sender )
Add ownership New Owner ( address )
Trigger Ethereum Event
Turn contract tradable , owners transfer token
Helper functions ( internal functions )
Add divisibility new owner
Add divisibility new owner
Remove divisibility last owner
Remove divisibility last owner
Withdraw Ether contract Multi sigin wallet
Modifier
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
Load Gifto IAMICOIN Contracts contract
ERC20 private Gifto = ERC20 ( 0x92e87a5622cf9955d1062822454701198a028a72 ) ;
ERC20 private IAMIToken = ERC20 ( 0xee10a06b2a0cf7e04115edfbee46242136eb6ae1 ) ;
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
Transfer GTO outside account
Transfer IAMI outside account
Change Gifto contract's address another type token , like Ether
@dev Create new forever rose

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization
control functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract
sender account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title ERC223
dev ERC223 contract interface ERC20 functions events
Fully backward compatible ERC20
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
title Contract Receiver
dev Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function data token transaction function execution
title MINATOKU
MINATOKU
dev MINATOKU ERC223 Token ERC20 functions events
Fully backward compatible ERC20
dev Prevent targets sending receiving tokens
param targets Addresses frozen
param Frozen either freeze
dev Prevent targets sending receiving tokens setting Unix times
param targets Addresses locked funds
param unix Times Unix times locking finished
dev Burns specific amount tokens
param address burn tokens
param unit Amount amount token burned
dev Function mint tokens
param address receive minted tokens
param unit Amount amount tokens mint
dev Function stop minting new tokens
dev Function distribute tokens list addresses provided amount
dev Function collect tokens list addresses
dev Function distribute tokens msg sender automatically
distribute Amount 0 , function work
dev token fallback function
MINATOKU TOKEN
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github Dexaran ERC223 token standard tree Recommended
ERC223 functions
ERC223 functions events
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

title Eternal Storage
dev contract holds necessary state variables carry storage contract
title Upgradeability Owner Storage
dev contract keeps track upgradeability owner
dev Tells address owner
return address owner
dev Sets address owner
title Proxy
dev Gives possibility delegate call foreign implementation
dev Tells address implementation every call delegated
return address implementation delegated
dev Fallback function allowing perform delegatecall given implementation
function return whatever implementation call returns
0x40 "free memory slot" , meaning pointer next slot empty memory mload ( 0x40 )
loads data free memory slot , `ptr` pointer next slot empty
memory needed we're going write return data delegatecall
free memory slot
`calldatacopy` copy calldatasize bytes calldata
First argument destination data copied ( ptr )
Second argument specifies start position copied data
Since calldata sort unique location memory ,
0 refer 0 memory 0 storage refers zeroth byte calldata
That's always going zeroth byte function selector
Third argument , calldatasize , specifies much data copied
calldata naturally calldatasize bytes long ( thing msg data length )
delegatecall params explained :
gas : amount gas provide call `gas` Opcode gives
us amount gas still available execution
impl : address contract delegate
ptr : pass copied data
calldatasize : loads size `bytes memory data` , msg data length
0 , 0 : `out` `outsize` params output could dynamic ,
set 0 , 0 output data written memory output
data read using `returndatasize` `returdatacopy` instead
result : 0 call fails 1 succeeds
ptr current points value stored 0x40 ,
assigned like ptr : = mload ( 0x40 )
use 0x40 free memory pointer ,
want make sure next time want allocate memory ,
overwriting anything important
, adding ptr returndatasize ,
get memory location beyond end data copying ptr
place 0x40 , reads 0x40 read free memory
`returndatacopy` Opcode copies last return data slot `ptr`
slot copy , 0 means copy beginning return data , size
amount data copy
`returndatasize` Opcode gives us size last return data case , size data returned delegatecall
`result` 0 , revert
`result` 1 , return `size` amount data `ptr` data
copied `ptr` delegatecall return data
title Upgradeability Storage
dev contract holds necessary state variables support upgrade functionality
dev Tells version name current implementation
return string representing name current version
dev Tells address current implementation
return address current implementation
title Upgradeability Proxy
dev contract represents proxy implementation address delegate upgraded
dev event emitted every time implementation gets upgraded
param version representing version name upgraded implementation
param implementation representing address upgraded implementation
dev Upgrades implementation address
param version representing version name new implementation set
param implementation representing address new implementation set
title Owned Upgradeability Proxy
dev contract combines upgradeability proxy basic authorization control functionalities
dev Event show ownership transferred
param previous Owner representing address previous owner
param new Owner representing address new owner
dev constructor sets original owner contract sender account
dev Throws called account owner
dev Tells address proxy owner
return address proxy owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev Allows upgradeability owner upgrade current version proxy
param version representing version name new implementation set
param implementation representing address new implementation set
dev Allows upgradeability owner upgrade current version proxy call new implementation
initialize whatever needed low level call
param version representing version name new implementation set
param implementation representing address new implementation set
param data represents msg data bet sent low level call parameter may include function
signature implementation called needed payload
title Eternal Storage Proxy
dev proxy holds storage token contract delegates every call current implementation set
Besides , allows upgrade token's behaviour towards implementations , provides basic
authorization control functionalities
File : contracts upgradeability Eternal Storage sol
File : contracts upgradeability Upgradeability Owner Storage sol
Owner contract
File : contracts upgradeability Proxy sol
File : contracts upgradeability Upgradeability Storage sol
Version name current implementation
Address current implementation
File : contracts upgradeability Upgradeability Proxy sol
File : contracts upgradeability Owned Upgradeability Proxy sol
File : contracts upgradeability Eternal Storage Proxy sol

dev Standard ERC677 function handle incoming token transfers
param Token sender address
param value Amount tokens
param data Transaction metadata
= MODIFIERS =
= EVENTS =
= CONFIGURABLES =
= DATASETS =
= PUBLIC FUNCTIONS =
APPLICATION ENTRY POINTS
Converts incoming ethereum tokens caller , passes referral addy ( )
Fallback function handle ethereum send straight contract
Unfortunately cannot use referral address way
Sends charity money https : giveth
charity address https : etherscan address 0x5ADF43DD006c6C36506e2b2DFA352E60002d22Dc
Converts caller's dividends tokens
Alias sell ( ) withdraw ( )
Withdraws callers earnings
Liquifies tokens ethereum
Transfer tokens caller new holder
REMEMBER 0% TRANSFER FEE
Transfer token specified address forward data recipient
ERC 677 standard
https : github ethereum EIPs issues 677
param Receiver address
param value Amount tokens transferred
param data Transaction metadata
Additional check game address sending tokens contract
assemble given address bytecode bytecode exists addr contract
function way spread dividends tokenholders contracts
ADMINISTRATOR FUNCTIONS
case amassador quota met , administrator manually disable ambassador phase
case one us dies , need replace
Precautionary measures case need adjust masternode rate
Add remove game contract , accept Proofof Humanity tokens
want rebrand ,
want rebrand ,
Set approved contracts purchase sell tokens ( ever need whale contract future )
HELPERS CALCULATORS
Method view current Ethereum stored contract
Example : total Ethereum Balance ( )
Retrieve total token supply
Retrieve tokens owned caller
Retrieve dividends owned caller
` include Referral Bonus` 1 true , referral bonus included calculations
reason , frontend , want get total divs ( global + ref )
internal calculations , want separate
Retrieve token balance single address
Retrieve dividend balance single address
Return buy price 1 individual token
Return sell price 1 individual token
Function frontend dynamically retrieve price scaling buy orders
Function frontend dynamically retrieve price scaling sell orders
Function frontend show ether waiting send charity contract
= INTERNAL FUNCTIONS =
Calculate Token price based amount incoming ethereum
algorithm , hopefully gave whitepaper scientific notation;
conversions occurred prevent decimal errors underflows overflows solidity code
Calculate token sell value
algorithm , hopefully gave whitepaper scientific notation;
conversions occurred prevent decimal errors underflows overflows solidity code
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Substracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
people tokens
people profits
administrators :
change name contract
change name token
change Po difficulty ( many tokens costs hold masternode , case gets crazy high later )
CANNOT :
take funds
disable withdrawals
kill contract
change price tokens
ensures first tokens contract equally distributed
meaning , divine dump ever possible
result : healthy longevity
still vulnerable phase ?
, enact anti early whale protocol
customer ambassador list ?
customer purchase exceed max ambassador quota ?
updated accumulated quota
execute
case ether count drops low , ambassador phase reinitiate
ERC20
20% dividend fee buy sell
2% charity fee buy sell
Address send charity ! : )
https : giveth
https : etherscan address 0x5ADF43DD006c6C36506e2b2DFA352E60002d22Dc
total ETH charity recieved contract
total ETH charity collected contract
proof stake ( defaults 100 tokens )
ambassador program
amount shares address ( scaled number )
administrator list ( see )
set true , ambassadors purchase tokens ( prevents whale premine , ensures fairly distributed upper pyramid )
Special Proofof Humanity Platform control scam game contracts Proofof Humanity platform
contracts , accept Proofof Humanity tokens
Special Proofof Humanity approved contracts purchase sell transfer Po H tokens
add administrators
add ambassadors
giveth
etherscan address 0x5ADF43DD006c6C36506e2b2DFA352E60002d22Dc
fetch dividends
retrieve ref bonus later code
pay dividends virtually
retrieve ref bonus
dispatch buy order virtualized "withdrawn dividends"
fire event
get token count caller & sell
lambo delivery service
setup data
get ref bonus later code
update dividend tracker
add ref bonus
lambo delivery service
fire event
setup data
Take dividends charity Payout
Add ethereum send charity
burn sold tokens
update dividends tracker
dividing zero bad idea
update amount dividends per token
fire event
setup
make sure requested tokens
also disables transfers ambassador phase
( dont want whale premines )
withdraw outstanding dividends first
exchange tokens
update dividend trackers
fire event
ERC20
github ethereum EIPs issues 677
security check contract approved Proofof Humanity platform
normal token transfer contract
retrieve size code target address , needs assembly
take amount dividends gained transaction , allocates evenly shareholder
calculation relies token supply , need supply Doh
calculation relies token supply , need supply Doh
Make sure send back excess user sends 5 ether 100 ETH contract
unapproved contracts allowed
check transaction 5 ether
check contract less 100 ether
data setup
point continuing execution OP poorfag russian hacker
prevents overflow case pyramid somehow magically starts used everyone world
( hackers )
yes know safemath function automatically rules "greater then" equasion
user referred masternode ?
referred purchase ?
cheating !
referrer least X whole tokens ?
e referrer godly chad masternode
wealth redistribution
ref purchase
add referral bonus back global dividends cake
can't give people infinite ethereum
add tokens pool
take amount dividends gained transaction , allocates evenly shareholder
calculate amount tokens customer receives purchase
add tokens pool
update circulating supply & ledger address customer
Tells contract buyer deserve dividends tokens owned them;
really know think
fire event
underflow attempts BTFO
underflow attempts BTFO
gas goes , sorry
sorry , probably paid 1 gwei
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization
control functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract
sender account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title ERC223
dev ERC223 contract interface ERC20 functions events
Fully backward compatible ERC20
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
title Contract Receiver
dev Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function data token transaction function execution
title NIZIGEN
NIZIGEN
dev NIZIGEN ERC223 Token ERC20 functions events
Fully backward compatible ERC20
dev Prevent targets sending receiving tokens
param targets Addresses frozen
param Frozen either freeze
dev Prevent targets sending receiving tokens setting Unix times
param targets Addresses locked funds
param unix Times Unix times locking finished
dev Burns specific amount tokens
param address burn tokens
param unit Amount amount token burned
dev Function mint tokens
param address receive minted tokens
param unit Amount amount tokens mint
dev Function stop minting new tokens
dev Function distribute tokens list addresses provided amount
dev Function collect tokens list addresses
dev Function distribute tokens msg sender automatically
distribute Amount 0 , function work
dev token fallback function
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github Dexaran ERC223 token standard tree Recommended
ERC223 functions
ERC223 functions events
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

Hauro Pay Presale info www hauropay
Designed www coincrowd
title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Authorizable
dev Authorizable contract authorized addresses , provides basic authorization control
functions , simplifies implementation "multiple user permissions"
dev Authorizable constructor sets first `authorized` contract sender
account
dev Throws called account authorized
dev Allows current owner set authorization
param address Authorized address change authorization
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev transfer token address another specified address
param sender address transfer
param address transfer
param value amount transferred
dev transfer token specified address ( Basic Token transfer method )
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
title Startable
dev Base contract allows owner implement start mechanism without ever stopped
dev Modifier make function callable contract started
dev called owner start , go normal state
title Startable token
dev Standard Token modified startable transfers
Approves calls receiving contract
dev Function burn tokens
param burner address token holder
param value amount token burned
dev Burns specific amount tokens
param value amount token burned
* @dev Burns tokens one address
* @param address address want burn tokens
* @param value uint256 amount tokens burned
dev transfer token tx orgin specified address ( Authorized contract )
dev Burns specific amount tokens tx orgin ( Authorized contract )
param value amount token burned
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
check budget allowed
1 Token wei
euro cents value 1 token
seconds 1970 01 01T00 : 00 : 00Z
seconds 1970 01 01T00 : 00 : 00Z
Configuration
Euro cents value 1 token
cent Token wei ether 04 12 2017
12 000 000 * 0 25 = 3 000 000 CAPPED
End Configuration
token Contract set Authorized ( , true ) ; Authorizable constructor set msg sender true
account charge updating token value
check started
check ended
Check remaining tokens
set remaining token 0
update remaining token without bonus

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Cash Vault Presale info www cashvault
Designed www coincrowd
title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Authorizable
dev Authorizable contract authorized addresses , provides basic authorization control
functions , simplifies implementation "multiple user permissions"
dev Authorizable constructor sets first `authorized` contract sender
account
dev Throws called account authorized
dev Allows current owner set authorization
param address Authorized address change authorization
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev transfer token address another specified address
param sender address transfer
param address transfer
param value amount transferred
dev transfer token specified address ( Basic Token transfer method )
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
title Startable
dev Base contract allows owner implement start mechanism without ever stopped
dev Modifier make function callable contract started
dev called owner start , go normal state
title Startable token
dev Standard Token modified startable transfers
Approves calls receiving contract
dev Function burn tokens
param burner address token holder
param value amount token burned
dev Burns specific amount tokens
param value amount token burned
* @dev Burns tokens one address
* @param address address want burn tokens
* @param value uint256 amount tokens burned
dev transfer token tx orgin specified address ( Authorized contract )
dev Burns specific amount tokens tx orgin ( Authorized contract )
param value amount token burned
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
check budget allowed
1 Token wei
euro cents value 1 token
seconds 1970 01 01T00 : 00 : 00Z
seconds 1970 01 01T00 : 00 : 00Z
Configuration
Euro cents value 1 token
cent Token wei ether 04 12 2017
12 000 000 * 0 25 = 3 000 000 CAPPED
End Configuration
token Contract set Authorized ( , true ) ; Authorizable constructor set msg sender true
account charge updating token value
check started
check ended
Check remaining tokens
set remaining token 0
update remaining token without bonus

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give owner 42Million initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give owner 0 initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

pragma solidity ^0 4 13;
pragma solidity ^0 4 13;
pragma solidity ^0 4 18;
import 'ds exec exec sol';
import 'ds note note sol';
hevm : flattened sources src spell sol
lib ds exec src exec sol
exec sol base contract used anything wants "untyped" calls
Copyright ( C ) 2017 Dapp Hub , LLC
program free software : redistribute modify
terms GNU General Public License published
Free Software Foundation , either version 3 License ,
( option ) later version
program distributed hope useful ,
WITHOUT WARRANTY; without even implied warranty
MERCHANTABILITY FITNESS PARTICULAR PURPOSE See
GNU General Public License details
received copy GNU General Public License
along program , see http : www gnu org licenses
Convenience aliases
lib ds note src note sol
note sol `note' modifier , logging calls events
program free software : redistribute modify
terms GNU General Public License published
Free Software Foundation , either version 3 License ,
( option ) later version
program distributed hope useful ,
WITHOUT WARRANTY; without even implied warranty
MERCHANTABILITY FITNESS PARTICULAR PURPOSE See
GNU General Public License details
received copy GNU General Public License
along program , see http : www gnu org licenses
src spell sol
spell sol un owned object performs one action one time
Copyright ( C ) 2017 Dapp Hub , LLC
program free software : redistribute modify
terms GNU General Public License published
Free Software Foundation , either version 3 License ,
( option ) later version
program distributed hope useful ,
WITHOUT WARRANTY; without even implied warranty
MERCHANTABILITY FITNESS PARTICULAR PURPOSE See
GNU General Public License details
received copy GNU General Public License
along program , see http : www gnu org licenses
marked 'done' CALL succeeds ( exceptional condition )

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give owner 0 initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
( balances[msg sender] = value && value 0 ) {
( balances[ from] = value && allowed[ from][msg sender] = value && value 0 ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
( balances[msg sender] = value && value 0 ) {
( balances[ from] = value && allowed[ from][msg sender] = value && value 0 ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
( balances[msg sender] = value && value 0 ) {
( balances[ from] = value && allowed[ from][msg sender] = value && value 0 ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Safe Math
dev Math operations safety checks throw error
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
ERC20 total fixed supply tokens
Account balances
transfer allowances
initial distributor responsible allocating supply
various pools described whitepaper
verified later event log
ERC20 balance ( )
ERC20 transfer ( )
Safe Math sub throw enough balance
ERC20 transfer ( )
ERC20 approve ( ) Comes standard caveat approval
meant limit spending may actually allow spent due
unfortunate ordering transactions safety , method
called current allowance 0 Alternatively ,
non ERC20 increase Approval ( ) decrease Approval ( ) used
ERC20 allowance ( )
officially ERC20 Allows allowance increased safely
officially ERC20 Allows allowance decreased safely
owner contract
total number minted tokens , excluding destroyed tokens
token balance released amount address
Whether token still mintable
Redeemable telcoin
Vesting period
Avoid loss precision multiplying later dividing
large value
owner contract
temporary token we're selling Sale tokens converted
immediately upon successful completion sale Bonus tokens
separate vesting schedule
token we'll convert sale ends
minimum maximum goals reach soft cap reached
end sale , contract enter refund mode
hard cap reached , contract finished early
Due actual soft cap tied USD assumption
value Ether continue increase ICO ,
implement fixed minimum softcap accounts 2 5x value
increase cap Flex scale factor allows us scale
caps fixed minimum values Initially scale factor
set effective soft cap ~10M USD
sale period
numnber tokens mint per wei
total number wei raised Note contract's balance may
differ value someone decided forcefully send us
ether
wallet receive contract's balance sale
finishes soft cap reached
list addresses allowed participate sale ,
amount , special rate may , provided
fact participate least minimum value
agreed
amount wei wei equivalents invested investor
enumerable list investors
Whether sale paused
Whether sale finished ,
Whether we're accepting refunds
total number wei refunded
Avoid loss precision multiplying later dividing
large value
beneficiary passed assigned minimum purchase level ?
pass minimum purchase level purchase ?
owner contract
actual sale
Whether escrow closed
amount wei wei equivalents invested investor

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Crowdsale
dev Crowdsale base contract managing token crowdsale
Crowdsales start end timestamps , investors make
token purchases crowdsale assign tokens based
token per ETH rate Funds collected forwarded wallet
arrive
title Capped Crowdsale
dev Extension Crowdsale max amount funds raised
start end timestamps investments allowed ( inclusive )
address funds collected
many token units buyer gets per wei
amount raised money wei
@return true transaction buy tokens
@return true crowdsale event ended
overriding Crowdsale valid Purchase add extra cap logic
@return true investors buy moment
overriding Crowdsale Ended add cap logic
@return true crowdsale event ended
token address
Bind User Account Address Wallet
fallback function used buy tokens
low level token purchase function
throw address bind another account
calculate token amount created
Mint message sender address
update state
get transfered account addresses
send ether fund collection wallet
override create custom fund forwarding mechanisms
change wallet
Remove contract

title Safe Math
dev Math operations safety checks throw error
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
CHANGE Update contract name
Token Name
many decimals show standard complicant keep 18
identifier : eg SBX , XPR etc
many units coin bought 1 ETH ?
WEI smallest unit ETH ( equivalent cent USD satoshi BTC ) We'll store total ETH raised via ICO
raised ETH go ?
constructor function
means following function name match contract name declared
Give creator initial tokens set 1000 example want initial tokens X decimal 5 , set value X * 100000 ( CHANGE )
Update total supply ( 1000 example ) ( CHANGE )
Set name display purposes ( CHANGE )
Amount decimals display purposes ( CHANGE )
Set symbol display purposes ( CHANGE )
Set price token ICO ( CHANGE )
owner contract gets ETH
Broadcast message blockchain
Transfer ether funds Wallet
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead
Credits Open Zeppelin contract taken Ethernaut CTF
https : ethernaut zeppelin solutions level 0x68756ad5e1039e4f3b895cfaa16a3a79a5a73c59
attacker call Delegate pwn ( ) context Delegation
means pwn ( ) modify state **Delegation** Delegate
result attacker takes unauthorized ownership contract

Copyright 2017 Loopring Project Ltd ( Loopring Foundation )
Licensed Apache License , Version 2 0 ( "License" ) ;
may use file except compliance License
may obtain copy License
http : www apache org licenses LICENSE 2 0
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND , either express implied
See License specific language governing permissions
limitations License
www apache org licenses LICENSE 2 0
@title Transferable Multisignature Contract
@ Daniel Wang [email protected]
Variables
( ) mutable state
immutable state
immutable state
immutable state
Constructor
Public Functions
default function nothing
Note address recovered signatures must strictly increasing
Follows ERC191 signature scheme :
https : github ethereum EIPs issues 191
Note address recovered signatures must strictly increasing
Follows ERC191 signature scheme :
https : github ethereum EIPs issues 191
Internal Functions
cannot 0x0 owner
remove current owners owner Map

Functions modifier executed owner
Functions modifier check sale status
allow sale selling
Functions modifier check validity address investor
Functions modifier check validity msg value
value must greater equal minimum Buy Price
total deposit must less equal maximum Buy Price
Public functions
Internal functions
Web3 call functions
Gifto Token Gifto Limited
ERC20 standard
: Gifto Team
Contact : [email protected]
Get total token supply
Get account balance another account address owner
Send value amount tokens address
transfer value amount token approved address
approve address value amount tokens
get remaining token approved owner spender
Triggered tokens transferred
Triggered whenever approve ( address spender , uint256 value ) called
initial selling
total supply 10^14 unit , equivalent 10^9 Gifto
original buy 1ETH = 4300 Gifto = 43 * 10**7 unit
Owner contract
Balances Gifto account
Owner account approves transfer amount another account
List approved investors
deposit
ico Percent
ico Supply avalable unit Initially , total Supply
minimum buy 0 3 ETH
maximum buy 25 ETH
total Token Sold
tradable
require value = minimum Buy total deposit msg sender = maximum Buy Price
@dev Fallback function allows buy ether
@dev buy function allows buy ether using optional data
prepare transfer data
increase total deposit amount
check total auto turn Sale
submit transfer
@dev Constructor
@dev Gets total Supply
@return Total supply
@dev Enables sale
@dev Disables sale
@dev set new ico Percent
@param new Ico Percent new value ico Percent
@dev set new maximum Buy
@param new Maximum Buy new value maximum Buy
@dev Updates buy price ( owner )
@param new Buy Price New buy price ( unit )
3000 Gifto = 3000 00000 unit
control maximum Buy USD = 10 , 000 USD , Gifto price 0 1USD
maximum Buy Gifto = 100 , 000 Gifto = 100 , 000 , 00000 unit
3000 Gifto = 1ETH = maximum ETH = 100 , 000 , 00000 original Buy Price
100 , 000 , 00000 3000 0000 ~ 33ETH = change wei
@dev Gets account's balance
@param addr Address account
@return Account balance
@dev check address approved investor
@param addr address
@dev get ETH deposit
@param addr address get deposit
@return amount deposit buyer
@dev Adds list new investors investors list approve
@param new Investor List Array new investors addresses added
@dev Removes list investors list
@param investor List Array addresses investors removed
@dev Transfers balance msg sender account
@param Recipient address
@param amount Transfered amount unit
@return Transfer status
sender's balance enough unit amount = 0 ,
sum overflow ,
transfer
Send value amount tokens address address
transfer method used withdraw workflow , allowing contracts send
tokens behalf , example "deposit" contract address charge
fees sub currencies; command fail unless account
deliberately authorized sender message via mechanism; propose
standardized APIs approval :
Allow spender withdraw account , multiple times , value amount
function called overwrites current allowance value
get allowance
@dev Withdraws Ether contract ( Owner )
@return Status withdrawal
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@dev Create new coin

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Constructor
investors= =
fix time inside
sponsors = =

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Fix ERC20 short address attack
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
Date start pre ICO
start Thursday , December 7 , 2017 12 : 00 : 00 EET
end Thursday , February 1 , 2018 12 : 00 : 00 EET
tokens blocked Tuesday , May 1 , 2018 12 : 00 : 00 EET
max tokens amount
token price ether
Fix ERC20 short address attack
init currency Crowdsale

Functions modifier executed owner
Functions modifier check sale status
allow sale selling
Functions modifier check validity address investor
Functions modifier check validity msg value
value must greater equal minimum Buy Price
total deposit must less equal maximum Buy Price
Functions modifier check validity range [a , b] = [0 , buyers length 1]
Public functions
Internal functions
Web3 call functions
GTO Token GTO Limited
ERC20 standard
: GTO Team
Contact : [email protected]
Get total token supply
Get account balance another account address owner
Send value amount tokens address
transfer value amount token approved address
approve address value amount tokens
get remaining token approved owner spender
Triggered tokens transferred
Triggered whenever approve ( address spender , uint256 value ) called
initial selling
total supply 10^14 unit , equivalent 10^9 GTO
original buy 1ETH = 4500 GTO = 45 * 10**7 unit
Owner contract
Balances GTO account
Owner account approves transfer amount another account
List approved investors
mapping Deposit
buyers buy token deposit
ico Percent
ico Supply avalable unit Initially , total Supply
minimum buy 0 3 ETH
maximum buy 30 ETH
require value = minimum Buy total deposit msg sender = maximum Buy Price
@dev Fallback function allows buy ether
@dev buy function allows buy ether using optional data
check first buy = push Array
add new buyer List
increase amount deposit buyer
transfer value directly owner
@dev Constructor
buyers = new address[] ( 1 ) ;
@dev Gets total Supply
@return Total supply
@dev Enables sale
@dev Disables sale
@dev set new ico Percent
@param new Ico Percent new value ico Percent
@dev set new maximum Buy
@param new Maximum Buy new value maximum Buy
@dev Updates buy price ( owner )
@param new Buy Price New buy price ( unit )
3000 GTO = 3000 00000 unit
control maximum Buy USD = 10 , 000 USD , GTO price 0 1USD
maximum Buy Gifto = 100 , 000 GTO = 100 , 000 , 00000 unit
3000 GTO = 1ETH = maximum ETH = 100 , 000 , 00000 original Buy Price
100 , 000 , 00000 3000 0000 ~ 33ETH = change wei
@dev Gets account's balance
@param addr Address account
@return Account balance
@dev check address approved investor
@param addr address
@dev get investors deposited
@dev get ETH deposit
@param addr address get deposit
@return amount deposit buyer
@dev Adds list new investors investors list approve
@param new Investor List Array new investors addresses added
@dev Removes list investors list
@param investor List Array addresses investors removed
@dev delivery token buyer
@param start point
@param b end point
make sure balances owner greater ico Supply
compute amount token buyer
check requested Units ico Supply
prepare transfer data
submit transfer
reset deposit buyer
@dev Transfers balance Multisig wallet account
@param Recipient address
@param amount Transfered amount unit
@return Transfer status
sender's balance enough unit amount = 0 ,
sum overflow ,
transfer
Send value amount tokens address address
transfer method used withdraw workflow , allowing contracts send
tokens behalf , example "deposit" contract address charge
fees sub currencies; command fail unless account
deliberately authorized sender message via mechanism; propose
standardized APIs approval :
Allow spender withdraw account , multiple times , value amount
function called overwrites current allowance value
get allowance
@dev Withdraws Ether contract ( Owner )
@return Status withdrawal
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@dev Create new coin

Created Boss Token 2017 https : www bosstoken org

title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Safe Math
dev Math operations safety checks throw error
title Basic token
dev Basic version Standard Token , allowances
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amout tokens transfered
dev Aprove passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifing amount tokens still available spender
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Burns specific amount tokens
param value amount token burned
dev use single lock whole contract
dev Prevents contract calling , directly indirectly
notice mark function `non Reentrant` , also
mark `external` Calling one non Reentrant function
another supported Instead , implement
`private` function actual work , `external`
wrapper marked `non Reentrant`
github ethereum EIPs issues 179
github ethereum EIPs issues 20
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
sec day
format 1 cent = price USD * wei
mint tokens USD investor

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

@title Merge Coin
@ Leon Huang [email protected]
token 18 digit precision
10 Million Tokens
pd : prod , tk : token Amount , et : ether Amount
@notice Initializes contract allocates initial tokens owner agreement account
80 percent goes public sale
accept ethers payable modifier
@notice transfer token contract ownership
@param new Owner address new owner contract
Owner transfer ERC20 tokens sent mistake

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

notice get balance specific address
contract user attempts get coins
Allow another contract user spend tokens behalf
Check sender enough
Check overflows
Check allowance
Subtract sender
Add recipient
contract name | contract info
ERC20 Events
ERC223 Event

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows owner execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

@ Jordi Baylina
Auditors : Griff Green & psdev
@notice Based http : hudsonjameson ethereummarriage
License : GNU 3
@dev `Owned` base level contract assigns `owner`
later changed
@dev `owner` address call function
modifier
@notice Constructor assigns message sender `owner`
@notice `owner` step assign address role
@param new Owner address new owner
unowned neutral vault , however cannot undone
@notice `new Owner` accept ownership transferred
account contract ability call `accept Ownership`
used accept ownership contract , including contract
functions
general safty function allows owner lot
things unlikely event something goes wrong
dst contract called making like 1 1 multisig
Marriage data variables
Set Owner
Create initial marriage contract
Set marriage status changes
Set IPFS hash image couple
Declare event structure

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent

Created Unix Coin https : unixcoin

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Created Bit Fin Tech TEAM 2017 https : bitfintech

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Constructor

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
b7f01af8bd882501f6801eb1eea8b22aa2a4979e https : github gnosis Multi Sig Wallet blob master contracts Multi Sig Wallet sol
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Constructor function
Add member
Make `target Member` member named `member Name`
param target Member ethereum address added
param member Name public name member
Remove member
notice Remove membership `target Member`
param target Member ethereum address removed
Change voting rules
Make proposals need tobe discussed least `minutes Debate 60` hours ,
least `minimum Quorum Proposals` votes , 50% + `margin Votes Majority` votes executed
param minimum Quorum Proposals many members must vote proposal executed
param minutes Debate minimum amount delay proposal made executed
param margin Votes Majority proposal needs 50% plus number
Add Proposal
Propose send `wei Amount 1e18` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
param beneficiary send ether
param wei Amount amount ether send , wei
param job Description Description job
param transaction Bytecode bytecode transaction
Add proposal Ether
Propose send `ether Amount` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
convenience function use amount given round number ether units
param beneficiary send ether
param ether Amount amount ether send
param job Description Description job
param transaction Bytecode bytecode transaction
Check proposal code matches
param proposal Number ID number proposal query
param beneficiary send ether
param wei Amount amount ether send
param transaction Bytecode bytecode transaction
Log vote proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param supports Proposal either favor
param justification Text optional justification text
Finish vote
Count votes proposal `proposal Number` execute approved
param proposal Number proposal number
param transaction Bytecode optional : transaction contained bytecode , need send
Contract Variables events
Modifier allows shareholders vote create new proposals
It’s necessary add empty first member
let's add founder , save step later
Get proposal
already voted , cancel
Set voter voted
Increase number votes
support proposal
Increase score
Decrease score
Create log event
past voting deadline
already executed
supplied code matches proposal
minimum quorum reached
execute result
Proposal passed; execute transaction
Avoid recursive calling
Proposal failed
Fire Events

Constructor function
Add member
Make `target Member` member named `member Name`
param target Member ethereum address added
param member Name public name member
Remove member
notice Remove membership `target Member`
param target Member ethereum address removed
Change voting rules
Make proposals need tobe discussed least `minutes Debate 60` hours ,
least `minimum Quorum Proposals` votes , 50% + `margin Votes Majority` votes executed
param minimum Quorum Proposals many members must vote proposal executed
param minutes Debate minimum amount delay proposal made executed
param margin Votes Majority proposal needs 50% plus number
Add Proposal
Propose send `wei Amount 1e18` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
param beneficiary send ether
param wei Amount amount ether send , wei
param job Description Description job
param transaction Bytecode bytecode transaction
Add proposal Ether
Propose send `ether Amount` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
convenience function use amount given round number ether units
param beneficiary send ether
param ether Amount amount ether send
param job Description Description job
param transaction Bytecode bytecode transaction
Check proposal code matches
param proposal Number ID number proposal query
param beneficiary send ether
param wei Amount amount ether send
param transaction Bytecode bytecode transaction
Log vote proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param supports Proposal either favor
param justification Text optional justification text
Finish vote
Count votes proposal `proposal Number` execute approved
param proposal Number proposal number
param transaction Bytecode optional : transaction contained bytecode , need send
Contract Variables events
Modifier allows shareholders vote create new proposals
It’s necessary add empty first member
let's add founder , save step later
Get proposal
already voted , cancel
Set voter voted
Increase number votes
support proposal
Increase score
Decrease score
Create log event
past voting deadline
already executed
supplied code matches proposal
minimum quorum reached
execute result
Proposal passed; execute transaction
Avoid recursive calling
Proposal failed
Fire Events

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Web3 call functions
Gifto
: Gifto Team
Contact : [email protected]
@title Multisignature wallet Allows multiple parties agree transactions execution
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
check duplicate owner invalid address
assign new owner
Fallback function allows deposit ether
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
remove last owner
@dev Update minimum required owner transaction validation
@param required number owners
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
transaction Id = sha3 ( destination , value , data , nonce ) ;
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
@dev Allows owner confirm transaction
@param transaction Id transaction Id
@dev Allows anyone execute confirmed transaction
@param transaction Id transaction Id
@dev Allows owner revoke confirmation transaction
@param transaction Id transaction Id
@dev Returns confirmation status transaction
@param transaction Id transaction Id
@return Confirmation status
@dev Returns number confirmations transaction
@param transaction Id transaction Id
@return Number confirmations
@dev Return list transactions filters applied
@param Pending pending status
@return List transactions
@dev Returns list pending transactions
@dev Returns list executed transactions

Funders Token Multi Sig Wallet Contract v1 0 0
deployer = wallet deployer
initialized
committees Map = committees' addresses indices
committees Array = index committee's address
committees Array Index Counter = counter committees Array
committees Number = number committees
committees Array [ committees Map [ test Address ] ] == 0x0 ? Committee : Committee
committee Join Votes = votes joining committee
committee Kick Votes = votes kicking committee
committee Join Voters = new Committee voter voted
committee Kick Voters = kicked Committee voter voted
tx Counter = multigis wallet's tx counter
tx Task Map = tx's index task
token Transfer Function Identifier Map = sha3 ( erc Version ) function identifier
tx task structure
add void address array[0]
0x0 committee
add deployer array[1]
set default erc20 token function identifier
0x0 cannot kicked
new Committee map array
kicked Committee map array
except kicked Committee
task type 1
task type 2
erc Version like :
erc20
erc223

Version : B
[email protected]
Overview :
Divides incoming funds among various `activity` accounts division cannot changed
contract locked
total funds credited account
current balance = credited amount withdrawn
percent allocation times ten
payout addr acct
need gt 1000 wei distribute
max accounts contract handle
deployer executor
accounts index
many activity accounts
amount received since begin time
amount distributed since begin time
amount withdrawn since begin time
gas withdrawals
constructor
reset
reset activity accounts
case funds withdrawn , become newly received undistributed
set withdrawal gas
nonstandard gas necessary support push withdrawals contract
add new activity account
get acct info
get total percentages x10
default payable function
call us plenty gas , catastrophe ensue
distribute funds activities
payout 1000 wei
account gets prescribed percentage holdover
also double check ensure amount credited cannot exceed total amount due acct
withdraw actvity balance
called owner push funds another contract
put back funds case err
suicide

Copyright ( C ) 2017 Halo Platform Scott Morrison
free software welcome redistribute certain conditions
ABSOLUTELY WARRANTY; details visit : https : www gnu org licenses gpl 2 0 html
tokens withdrawable
store ether & tokens period time

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

ether sent address , send back

b
b
ether sent address , send back

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Functions modifier executed owner
Functions modifier executed users except owners
Functions modifier check sale status
allow sale selling
Functions modifier check validity original buy price
Functions modifier check validity address investor
Functions modifier check validity msg value
value must greater equal minimum Buy Price
total deposit must less equal maximum Buy Price
Web3 call functions
Gifto Token Gifto Limited
ERC20 standard
: Gifto Team
Contact : [email protected]
Get total token supply
Get account balance another account address owner
Send value amount tokens address
Triggered tokens transferred
Triggered whenever approve ( address spender , uint256 value ) called
initial selling
total supply 10^14 unit , equivalent 10^9 Gifto
original buy wei one unit Ajustable
Owner contract
Balances Gifto account
List approved investors
mapping Deposit
buyers buy token deposit
ico Percent
ico Supply avalable unit Initially , total Supply
minimum buy 0 1 ETH
maximum buy 30 ETH
value minimum Buy total deposit msg sender maximum Buy Price
@dev Fallback function allows buy ether
check first buy = push Array
add new buyer List
increase amount deposit buyer
@dev Constructor
@dev Gets total Supply
@return Total supply
@dev set new ico Percent
@param new Ico Percent new value ico Percent
@dev set new minimum Buy
@param new Minimum Buy new value minimum Buy
@dev set new maximum Buy
@param new Maximum Buy new value maximum Buy
@dev Gets account's balance
@param addr Address account
@return Account balance
@dev check address approved investor
@param addr address
@dev filter buyers list buyers
@param Investor type buyers , investor
@dev filter buyers investor list deposited
@dev filter normal Buyers list buyer deposited
@dev get ETH deposit
@param addr address get deposit
@return amount deposit buyer
@dev get total deposit buyers
@return amount ETH deposit
@dev delivery token buyer
@param Investor transfer token investor
true : investors
false : investors
sumary deposit investors
compute amount token buyer
check requested Units ico Supply
prepare transfer data
NOTE : make sure balances owner greater ico Supply
submit transfer
reset deposit buyer
transfer total ETH investors owner
@dev return ETH normal buyers
buyer approve investor
get deposit buyer
reset deposit buyer
return deposit amount buyer
@dev Transfers balance Multisig wallet account
@param Recipient address
@param amount Transfered amount unit
@return Transfer status
sender's balance enough unit amount = 0 ,
sum overflow ,
transfer
@dev Enables sale
@dev Disables sale
@dev Gets selling status
@dev Updates buy price ( owner )
@param new Buy Price New buy price ( unit )
@dev Adds list new investors investors list approve
@param new Investor List Array new investors addresses added
@dev Removes list investors list
@param investor List Array addresses investors removed
@dev Buys Gifto
@return Amount requested units
convert buy amount wei number unit want buy
check requested Units = ico Supply
prepare transfer data
decrease ico Supply
submit transfer
transfer ETH owner
@dev Withdraws Ether contract ( Owner )
@return Status withdrawal
@title Multisignature wallet Allows multiple parties agree transactions execution
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
check duplicate owner invalid address
assign new owner
Fallback function allows deposit ether
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
remove last owner
@dev Update minimum required owner transaction validation
@param required number owners
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
transaction Id = sha3 ( destination , value , data , nonce ) ;
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
@dev Allows owner confirm transaction
@param transaction Id transaction Id
@dev Allows anyone execute confirmed transaction
@param transaction Id transaction Id
@dev Allows owner revoke confirmation transaction
@param transaction Id transaction Id
@dev Returns confirmation status transaction
@param transaction Id transaction Id
@return Confirmation status
@dev Returns number confirmations transaction
@param transaction Id transaction Id
@return Number confirmations
@dev Return list transactions filters applied
@param Pending pending status
@return List transactions
@dev Returns list pending transactions
@dev Returns list executed transactions
@dev Create new coin

Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
human 0 1 standard arbitrary versioning scheme
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Edgeless Casino Proxy Contract Serves proxy game functionality
Allows players deposit withdraw funds
Allows authorized addresses make game transactions
: Julia Altenried
total balance players 4 virtual decimals
balance per player edgeless tokens 4 virtual decimals
case user wants needs call withdraw function wallet , first needs request withdrawal
price per kgas tokens ( 4 decimals )
average amount gas consumend per game
edgeless token contract
owner able close contract nobody using least 30 days
informs listeners many tokens deposited player
informs listeners many tokens withdrawn player receiver address
* accepts deposits arbitrary address
* retrieves tokens message sender adds balance specified address
* edgeless tokens decimals , represented contract 4 decimals
* @param receiver address receiver
* num Tokens number tokens deposit ( 0 decimals )
* charge Gas indicates gas cost subtracted user's edgeless token balance
* user wants needs withdraw funds , needs request withdrawal first
* method sets earliest possible withdrawal date 7 minutes
* Reason : user able withdraw funds , last game methods yet mined
* case user requested withdrawal changes mind
* Necessary able continue playing
* withdraws amount user balance 7 minutes passed since request
* @param amount amount tokens withdraw
* lets owner withdraw bankroll
* @param num Tokens number tokens withdraw ( 0 decimals )
* returns current bankroll tokens 0 decimals
* lets owner close contract player funds nobody using least 30 days
* case close called accidentally
* make sure contract process closed
* delays time closing
indicates address authorized call game functions
indicates user allowed casino game address move funds
counts often address deauthorized user = make sure signatzures can't reused
list casino game contract addresses
number count withdrawal signatures ensure signature different even withdrawing amount address
creates new casino wallet
param authorized Address address may send transactions Edgeless Casino
blackjack Address address Edgeless blackjack contract
* token Contract address Edgeless token contract
* shifts tokens contract balance player way round
* callable edgeless casino contract sender must approved user
* @param player address player
* num Tokens amount tokens shift 4 decimals
* Receiver tells player receiving token way round
transfers amount contract balance owner's wallet
param receiver receiver address
* amount amount tokens withdraw ( 0 decimals )
* v , r , signature player
update casino game address case new contract new casino game
param game index game
new Address new address game
authorize address call game functions
param addr address authorized
deauthorize address call game functions
param addr address deauthorized
authorize casino contract address access funds
param casino Address address casino contract
v , r , player's signature casino address , number times address already locked
bool stating signature meant authourization ( true ) deauthorization ( false )
deauthorize casino contract address access funds
param casino Address address casino contract
v , r , player's signature casino address , number times address already locked
bool stating signature meant authourization ( true ) deauthorization ( false )
* updates price per 1000 gas EDG
* @param price new gas price ( 4 decimals , max 0 0256 EDG )
* updates average amount gas consumed game
* @param game index game contract
* gas new avg gas
Forwards move corresponding game contract data signed client
casino contract ensures duplicate move
param game specifies game contract call
data function call
v , r , player's signature data
checks given address passed first parameters bytes field
param player player address
data function call
internals
make impossible reuse old signature authorize address

Edgeless Casino Proxy Contract Serves proxy game functionality
Allows players deposit withdraw funds
Allows authorized addresses make game transactions
: Julia Altenried
total balance players 4 virtual decimals
balance per player edgeless tokens 4 virtual decimals
case user wants needs call withdraw function wallet , first needs request withdrawal
price per kgas tokens ( 4 decimals )
edgeless token contract
owner able close contract nobody using least 30 days
informs listeners many tokens deposited player
informs listeners many tokens withdrawn player receiver address
* accepts deposits arbitrary address
* retrieves tokens message sender adds balance specified address
* edgeless tokens decimals , represented contract 4 decimals
* @param receiver address receiver
* num Tokens number tokens deposit ( 0 decimals )
* charge Gas indicates gas cost subtracted user's edgeless token balance
* user wants needs withdraw funds , needs request withdrawal first
* method sets earliest possible withdrawal date 7 minutes
* Reason : user able withdraw funds , last game methods yet mined
* case user requested withdrawal changes mind
* Necessary able continue playing
* withdraws amount user balance 7 minutes passed since request
* @param amount amount tokens withdraw
* lets owner withdraw bankroll
* @param num Tokens number tokens withdraw ( 0 decimals )
* returns current bankroll tokens 0 decimals
* lets owner close contract player funds nobody using least 30 days
* case close called accidentally
* make sure contract process closed
* delays time closing
indicates address authorized call game functions
indicates user allowed casino game address move funds
counts often address deauthorized user = make sure signatzures can't reused
list casino game contract addresses
number count withdrawal signatures ensure signature different even withdrawing amount address
creates new casino wallet
param authorized Address address may send transactions Edgeless Casino
blackjack Address address Edgeless blackjack contract
* token Contract address Edgeless token contract
* shifts tokens contract balance player way round
* callable edgeless casino contract sender must approved user
* @param player address player
* num Tokens amount tokens shift 4 decimals
* Receiver tells player receiving token way round
transfers amount contract balance owner's wallet
param receiver receiver address
* amount amount tokens withdraw ( 0 decimals )
* v , r , signature player
update casino game address case new contract new casino game
param game index game
new Address new address game
authorize address call game functions
param addr address authorized
deauthorize address call game functions
param addr address deauthorized
authorize casino contract address access funds
param casino Address address casino contract
v , r , player's signature casino address , number times address already locked
bool stating signature meant authourization ( true ) deauthorization ( false )
deauthorize casino contract address access funds
param casino Address address casino contract
v , r , player's signature casino address , number times address already locked
bool stating signature meant authourization ( true ) deauthorization ( false )
* updates price per 1000 gas EDG
* @param price new gas price ( 4 decimals , max 0 0256 EDG )
Forwards move corresponding game contract data signed client
casino contract ensures duplicate move
param game specifies game contract call
data function call
v , r , player's signature data
checks given address passed first parameters bytes field
param player player address
data function call
internals
point good deal gas already consumend , maybe better fix price
make impossible reuse old signature authorize address

Edgeless blackjack contract allows calls authorized casino proxy contracts
proxy contract forward moves called authorized wallet owned Edgeless casino , game
data signed player show approval way , Edgeless provide fluid game experience
without wait transaction confirmations
: Julia Altenried
minimum bet
maximum bet
tells address authorized call game functions
constructur initialize contract initial values
param min Bet minimum bet
max Bet maximum bet
allows owner change minimum bet
param new Min new minimum bet
allows owner change maximum bet
param new Max new maximum bet
authorize address call game functions
param addr address authorized
deauthorize address call game functions
param addr address deauthorized
checks address authorized call game functionality
value cards : Ace , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , J , Q , K Ace 1 11 , course
value card determined looking card Values[card Id%13]
tells player already claimed win
bets games case initialized stand
list splits per game length 0 cases
tells hand given game doubled
notify listeners new round blackjack started
notify listeners game outcome
notify listeners player doubled
notify listeners player split
constructur initialize contract minimum bet
param min Bet minimum bet
max Bet maximum bet
initializes round blackjack
accepts bet
throws exception bet low game given id already played bet already paid
param player address player
value value bet tokens
deck hash deck
srv Seed hash server seed
c Seed plain client seed
doubles bet game given id correct amount sent player double hand yet
param player player address
id game id
hand index hand doubled
value number tokens sent player
splits hands game given id correct amount sent player address player
split yet
param player player address
id game id
hand index hand split
value number tokens sent player
surrendering half bet returned player
send plain server seed check correct
param player player address
seed server seed
bet original bet
first checks deck player's number cards correct , checks player , sends win
param player player address
deck partial deck
seed plain server seed
num Cards number cards per hand
splits array splits
doubled array indicating hand doubled
bet original bet
deck Hash hash deck ( verification logging )
c Seed client seed ( logging )
check deck casino seed correct
param deck partial deck
seed server seed
deck Hash hash deck
return true correct
converts uint8 array bytes
param byte Array uint8 array converted
return bytes
checks correct amount paid initial bet + splits doubles
param game Id game id
bet bet
return true correct
determines outcome game returns win
case loss , win 0
param cards cards partial deck
num Cards number cards per hand
splits array splits
doubled array indicating hand doubled
bet original bet
return total win hands
calculates value player's hands
param cards holds ( partial ) deck
num Cards number cards per player hand
p Splits player's splits ( hand index )
return values player's hands
recursively plays player's hands
param h Index hand index
c Index index next card draw
Index index next split ,
player Values values player's hands ( yet complete )
cards holds ( partial ) deck
num Cards number cards per player hand
p Splits array splits
return values player's hands current card index
calculates value dealer's hand
param cards holds ( partial ) deck
num Cards number cards player holds
return value dealer's hand flag indicating dealer got blackjack
sums given numbers
note : overflow possible player always hold less 100 cards
param numbers numbers sum
return sum numbers
throw game id already exists later maybe throw game id still running
make sure game payed already
make sure game initialized transfered value correct
make sure hand doubled yet
make sure game initialized transfered value correct
plausibility check
init Game method called
pay back bet
shift balance player casino
bust value 21
player blackjack dealer blackjack
pay 3 2
player wins regularly
tie
player looses
dealer always receives second forth card
2 aces , count 12
take cards value reaches 17

Original : Cintix
Modified : yakois
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Maximum amount user ETH contract accept
minimum amount ETH must deposited buy performed
owner's address
crowdsale address set known
Constructor Sets sender owner contract
Allows developer set crowdsale address
allow developer set sale token addresses
allow setting addresses
Set crowdsale token addresses
Allows user withdraw tokens
Token's ERC20 address argument unknow time deployement
Tokens must bought
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
Send funds Throws failure prevent loss funds
Allows caller get eth refunded
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Buy tokens Sends ETH presale wallet records ETH amount held contract
allow owner perform buy
Short circuit save gas contract already bought tokens
pre sale address set
Throw contract balance less minimum required amount
Record contract bought tokens
Record amount ETH sent contract's current value
Transfer funds crowdsale address
owner raise cap
Raise cap
Default function Called user sends ETH contract
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Events
Storage
Public functions
Internal functions
Public functions
Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@dev Returns number instantiations creator
@param creator Contract creator
@return Returns number instantiations creator
@dev Registers contract factory registry
@param instantiation Address contract instantiation
@title Multisignature wallet factory Allows creation multisig wallet
@ Stefan George [email protected]
@dev Allows verified creation multisignature wallet
@param owners List initial owners
@param required Number required confirmations
@return Returns wallet address
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Events
Storage
Public functions
Internal functions
Public functions
Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
@dev Returns number instantiations creator
@param creator Contract creator
@return Returns number instantiations creator
@dev Registers contract factory registry
@param instantiation Address contract instantiation
@title Multisignature wallet factory Allows creation multisig wallet
@ Stefan George [email protected]
@dev Allows verified creation multisignature wallet
@param owners List initial owners
@param required Number required confirmations
@return Returns wallet address
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Constructor
investors= =
fix time inside
sponsors = =

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Constructor function
Add member
Make `target Member` member named `member Name`
param target Member ethereum address added
param member Name public name member
Remove member
notice Remove membership `target Member`
param target Member ethereum address removed
Change voting rules
Make proposals need tobe discussed least `minutes Debate 60` hours ,
least `minimum Quorum Proposals` votes , 50% + `margin Votes Majority` votes executed
param minimum Quorum Proposals many members must vote proposal executed
param minutes Debate minimum amount delay proposal made executed
param margin Votes Majority proposal needs 50% plus number
Add Proposal
Propose send `wei Amount 1e18` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
param beneficiary send ether
param wei Amount amount ether send , wei
param job Description Description job
param transaction Bytecode bytecode transaction
Add proposal Ether
Propose send `ether Amount` ether `beneficiary` `job Description` `transaction Bytecode ? Contains : contain` code
convenience function use amount given round number ether units
param beneficiary send ether
param ether Amount amount ether send
param job Description Description job
param transaction Bytecode bytecode transaction
Check proposal code matches
param proposal Number ID number proposal query
param beneficiary send ether
param wei Amount amount ether send
param transaction Bytecode bytecode transaction
Log vote proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param supports Proposal either favor
param justification Text optional justification text
Finish vote
Count votes proposal `proposal Number` execute approved
param proposal Number proposal number
param transaction Bytecode optional : transaction contained bytecode , need send
Contract Variables events
Modifier allows shareholders vote create new proposals
It’s necessary add empty first member
let's add founder , save step later
Get proposal
already voted , cancel
Set voter voted
Increase number votes
support proposal
Increase score
Decrease score
Create log event
past voting deadline
already executed
supplied code matches proposal
minimum quorum reached
execute result
Proposal passed; execute transaction
Avoid recursive calling
Proposal failed
Fire Events

Events
Constants
Storage
Modifiers
Public functions
Internal functions
Web3 call functions
Events
Storage
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param new Owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George [email protected]
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

High value , community controlled token
ERC20 interface
see https : github ethereum EIPs issues 20
Safe Math lowest gas library
Math operations safety checks throw error
Basic token
Basic version Standard Token , allowances
Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
Implementation basic standard token
https : github ethereum EIPs issues 20
Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amout tokens transfered
Aprove passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount Roman Lanskoj's tokens spent
Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifing amount tokens still available spender
Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
Throws called account owner
Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
Converts 10MTI tokens approve ( ) 'd msg sender contract
github ethereum EIPs issues 20
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 20
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
Original 10MTI contract
real
Manager account initially holding 50M tokens
real
burn 10MTI
transfer ( manager , msg sender , tokens Transfer ) ; either called `this call transfer ( ) '
inlined

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
Variables token contract
Variables bounty manager
Functions contract
Modifiers contract
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
dev Burns specific amount tokens
param value amount token burned
Public variables token ERC20 compliance
Public variables specific Peculium
Event freeze account
Public Functions contract
Owner Functions contract
Others Functions contract
Approves calls receiving contract
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
Peculium token
boolean know Peculium token address init
address bounty manager
nb token bountymanager
boolean test first pay send bountymanager
pourcent first pay rate
pourcent montly pay rate
boolean know bounty address init
Day bounty manager paid
montly pay sent 6 months
Constructor
allocate 72 million token bounty manager ( maybe change )
first pay 40%
pay 10%
init address token
change bounty manager address
Transfer pecul Bounty manager
need initialize first token contract
need initialize first address bounty Manager
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
token standard ERC20 Token burnable ownable aptitude
use safemath basic math operation ( + , , * , )
token name
token symbol
token number decimal
max cap 20 Billion Peculium
date deployment token
boolean variable , frost tokens
date owners token defrost tokens
Constructor
beginning , owner tokens
owner need sell token private sale pre ICO , ICO
everybody defrost token 25 january 2018 ( 85 days 1 November )
Function defrost token , date defrost
overright transfer function allow freeze possibility
overright transfer function allow freeze possibility ( need allow )
Return info public address balance account owner contract

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
ether sent address , send back
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
Functions contract
Modifiers contract
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
dev Burns specific amount tokens
param value amount token burned
Public variables token ERC20 compliance
Public variables specific Peculium
Event freeze account
Public Functions contract
Owner Functions contract
Others Functions contract
Approves calls receiving contract
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
Airdrop total amount
decimal token
token Peculium
need first init Peculium Token address
Event one airdrop
Event airdrop
Constructor
allocate 28 Millions token airdrop ( maybe change )
init Peculium token address
Looping input arrays assign target amount given address
first test enough token send
enough token , cancel sell
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
token standard ERC20 Token burnable ownable aptitude
use safemath basic math operation ( + , , * , )
token name
token symbol
token number decimal
max cap 20 Billion Peculium
date deployment token
boolean variable , frost tokens
date owners token defrost tokens
Constructor
beginning , owner tokens
owner need sell token private sale pre ICO , ICO
everybody defrost token 25 january 2018 ( 85 days 1 November )
Function defrost token , date defrost
overright transfer function allow freeze possibility
overright transfer function allow freeze possibility ( need allow )
Return info public address balance account owner contract

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
dev Burns specific amount tokens
param value amount token burned
Public variables token ERC20 compliance
Public variables specific Peculium
Event freeze account
Public Functions contract
Owner Functions contract
Others Functions contract
Approves calls receiving contract
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Safe Math sub throw enough balance
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
token standard ERC20 Token burnable ownable aptitude
use safemath basic math operation ( + , , * , )
token name
token symbol
token number decimal
max cap 20 Billion Peculium
date deployment token
boolean variable , frost tokens
date owners token defrost tokens
Constructor
beginning , owner tokens
owner need sell token private sale pre ICO , ICO
everybody defrost token 25 january 2018 ( 85 days 1 November )
Function defrost token , date defrost
overright transfer function allow freeze possibility
overright transfer function allow freeze possibility ( need allow )
Return info public address balance account owner contract

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
dev Pause token transfer successfully finished crowdsale becomes false
dev Accounts transfer token even paused Works crowdsale
dev Wrapper token transfer
dev Wrapper token transfer
dev Mint timelocked tokens
dev Release frozen tokens
return Total amount released tokens
dev Burns specific amount tokens
param value amount token burned
= 1 ETH
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Timestamp token release enabled
ERC20 basic token contract held
ERC20Basic token;
ERC20Basic
require ( = release Time ) ;
require ( amount 0 ) ;
token safe Transfer ( beneficiary , amount ) ;
require ( token transfer ( beneficiary , amount ) ) ;
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
( uint x = 0; x frozen Storages length; x++ ) {
uint amount = balance ( frozen Storages[x] ) ;
( frozen Storages[x] call ( bytes4 ( sha3 ( "release ( address ) " ) ) , msg sender ) )
total = total add ( amount ) ;

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Refund Vault
dev contract used storing funds crowdsale
progress Supports refunding money crowdsale fails ,
forwarding crowdsale successful
title Crowdsale
dev Crowdsale base contract managing token crowdsale
Crowdsales start end timestamps , investors make
token purchases crowdsale assign tokens based
token per ETH rate Funds collected forwarded wallet
arrive
dev Amount already sold tokens
dev Maximum amount tokens mint
event token purchase logging
param purchaser paid tokens
param beneficiary got tokens
param value weis paid purchase
param amount amount tokens purchased
dev method might overridden implementing sale logic
return Actual rate
dev Check specified purchase valid
return true transaction buy tokens
dev discount Ended might true , valid Purchase returns false
return true crowdsale event ended
return true crowdsale event started
title Finalizable Crowdsale
dev Extension Crowsdale owner extra work
finishing
dev Must called crowdsale ends , extra finalization
work Calls contract's finalization function
dev overriden add finalization logic overriding function
call super finalization ( ) ensure chain finalization
executed entirely
title Refundable Crowdsale
dev Extension Crowdsale contract adds funding goal ,
possibility users getting refund goal met
Uses Refund Vault crowdsale's vault
Constructor function
dev Release delayed bonus tokens
return Amount got bonus tokens
dev Trasfer bonuses adding delayed bonuses
param beneficiary Future bonuses holder
param tokens Amount bonus tokens
dev Initialization crowdsale Starts deployment token contract
, deployment crowdsale contract changу token contract's owner
dev Mint tokens name founders freeze part
dev Purchase bitcoin start btc buyer
dev Set new address buy tokens bitcoin
dev Finish crowdsale
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Issue : * https : github Open Zeppelin zeppelin solidity issues 120
Based code Token Market Net : https : github Token Market Net ico blob master contracts Mintable Token sol
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
dev Pause token transfer successfully finished crowdsale becomes false
dev Accounts transfer token even paused Works crowdsale
dev Wrapper token transfer
dev Wrapper token transfer
dev Mint timelocked tokens
dev Release frozen tokens
return Total amount released tokens
dev Burns specific amount tokens
param value amount token burned
= 1 ETH
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Timestamp token release enabled
ERC20 basic token contract held
ERC20Basic token;
ERC20Basic
require ( = release Time ) ;
require ( amount 0 ) ;
token safe Transfer ( beneficiary , amount ) ;
require ( token transfer ( beneficiary , amount ) ) ;
token sold
start end timestamps investments allowed ( inclusive )
address funds collected
many token units buyer gets per wei
amount raised money wei
token = create Token Contract ( ) ;
creates token sold
override method crowdsale specific mintable token
function create Token Contract ( ) internal returns ( Mintable Token ) {
return new Mintable Token ( ) ;
Fallback function used buy tokens
Low level token purchase function
Total minted tokens
Actual token minting rate ( considering bonuses discounts )
Calculate token amount created
uint tokens = rate mul ( msg value ) div ( 1 ether ) ;
btc purchase check existence tokens ( change )
Change , minted token would less
hard cap reached
Rest tokens
Rest tokens rounded actual Rate
Bonuses
Update state
Send ether fund collection wallet
Override create custom fund forwarding mechanisms
Trasfer bonuses adding delayed bonuses
minimum amount funds raised weis
refund vault used hold funds crowdsale running
We're overriding fund forwarding Crowdsale
addition sending funds , want call
Refund Vault deposit function
crowdsale unsuccessful , investors claim refunds
vault finalization task , called owner calls finalize ( )
overall 100 00%
20 00% Founders
5 00% Pre sale
Mainnet addresses
4000000 EUR
b Provider transfer Ownership ( owner ) ;
bonuses
mint bonus token bonus provider
change token owner
1 ) 10% investment first week
2 ) 10% investors ICO ( presale ) reach 5 000 000 euro investments
5 000 000 EUR 20 000 ETH ETR
Apply bonus amount
send remaining bonuses
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
github Open Zeppelin zeppelin solidity issues 120
github Token Market Net ico blob master contracts Mintable Token sol
( uint x = 0; x frozen Storages length; x++ ) {
uint amount = balance ( frozen Storages[x] ) ;
( frozen Storages[x] call ( bytes4 ( sha3 ( "release ( address ) " ) ) , msg sender ) )
total = total add ( amount ) ;

Web3 call functions
Edoo PAD Inc
ERC20 standard
: Edoo PAD Inc
Contact : [email protected]
@title Multisignature wallet Allows multiple parties agree transactions execution
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Update minimum required owner transaction validation
@param required number owners
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
transaction Id = sha3 ( destination , value , data , nonce ) ;
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@param nonce
@return transaction Id
@dev Allows owner confirm transaction
@param transaction Id transaction Id
@dev Allows anyone execute confirmed transaction
@param transaction Id transaction Id
happen txn executed revert ( ) executed ?
@dev Allows owner revoke confirmation transaction
@param transaction Id transaction Id
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
included code ?
( Owner[ owners[i]] || owners[i] == 0 )
throw;
Fallback function allows deposit ether
@dev Returns confirmation status transaction
@param transaction Id transaction Id
@return Confirmation status
@dev Returns number confirmations transaction
@param transaction Id transaction Id
@return Number confirmations
@dev Return list transactions filters applied
@param Pending pending status
@return List transactions
@dev Returns list pending transactions
@dev Returns list executed transactions

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

New ERC23 contract interface
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
Fully backward compatible ERC20
Include Safe Math Lib
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
github Dexaran ERC223 token standard tree Recommended *
ERC223 ERC20 functions events
ERC20 functions events
ERC223 functions events
Initialize owner 100 , 000 , 000 , 000 EDOGE contract creation
Constructor called called ( Ethereum Solidity specification )
Security check case EVM future flaw exploit call constructor multiple times
Ensure token gets created
Final sanity check ensure owner balance greater zero
Function distribute tokens list addresses provided amount
Verify require :
Balance owner cannot negative
transfers fulfilled remaining owner balance
new tokens ever minted except originally created 100 , 000 , 000 , 000
proceed enough tokens distributed addresses
Never allow balance owner become negative
Another sanity check make sure owner balance never negative
Function access name token sha
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
allow transfer unlocked
unlocked , unlocked forever one lock
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract
Get balance address provided
Creator Owner unlocked never locked
Use airdrop complete
allow transfer unlocked
unlocked , unlocked forever one lock
Replace line following want protect wrapping uints
require ( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) ;

New ERC23 contract interface
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
Fully backward compatible ERC20
Include Safe Math Lib
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
github Dexaran ERC223 token standard tree Recommended *
Initialize owner 100 , 000 , 000 , 000 EDOGE contract creation
Constructor called called ( Ethereum Solidity specification )
Security check case EVM future flaw exploit call constructor multiple times
Ensure token gets created
Final sanity check ensure owner balance greater zero
Function distribute tokens list addresses provided amount
Verify require :
Balance owner cannot negative
transfers fulfilled remaining owner balance
new tokens ever minted except originally created 100 , 000 , 000 , 000
proceed enough tokens distributed addresses
Never allow balance owner become negative
Another sanity check make sure owner balance never negative
Function access name token sha
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
allow transfer unlocked
unlocked , unlocked forever one lock
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract
Get balance address provided
Creator Owner unlocked never locked
Use airdrop complete
allow transfer unlocked
unlocked , unlocked forever one lock
Replace line following want protect wrapping uints
require ( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) ;

New ERC23 contract interface
Recommended implementation used https : github Dexaran ERC223 token standard tree Recommended
Fully backward compatible ERC20
Include Safe Math Lib
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
github Dexaran ERC223 token standard tree Recommended *
Initialize owner 100 , 000 , 000 , 000 EDOGE contract creation
Constructor called called ( Ethereum Solidity specification )
Security check case EVM future flaw exploit call constructor multiple times
Ensure token gets created
Final sanity check ensure owner balance greater zero
Function distribute tokens list addresses provided amount
Verify require :
Balance owner cannot negative
transfers fulfilled remaining owner balance
new tokens ever minted except originally created 100 , 000 , 000 , 000
proceed enough tokens distributed addresses
Never allow balance owner become negative
Another sanity check make sure owner balance never negative
Function access name token sha
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Function called user another contract wants transfer funds
allow transfer unlocked
unlocked , unlocked forever one lock
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
allow transfer unlocked
unlocked , unlocked forever one lock
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract
Get balance address provided
Creator Owner unlocked never locked
Use airdrop complete

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Safe Math
dev Math operations safety checks throw error
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Authorizable
dev Authorizable contract authorized addresses , provides basic authorization control
functions , simplifies implementation "multiple user permissions"
dev Authorizable constructor sets first `authorized` contract sender
account
dev Throws called account authorized
dev Allows current owner set authorization
param address Authorized address change authorization
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Basic token
dev Basic version Standard Token , allowances
dev transfer token address another specified address
param sender address transfer
param address transfer
param value amount transferred
dev transfer token specified address ( Basic Token transfer method )
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
title Standard ERC20 token
dev Implementation basic standard token
dev https : github ethereum EIPs issues 20
dev Based code First Blood : https : github Firstbloodio token blob master smart contract First Blood Token sol
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Approve passed address spend specified amount tokens behalf msg sender
Beware changing allowance method brings risk someone may use old
new allowance unfortunate transaction ordering One possible solution mitigate
race condition first reduce spender's allowance 0 set desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
approve called allowed[ spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
title Startable
dev Base contract allows owner implement start mechanism without ever stopped
dev Modifier make function callable contract started
dev called owner start , go normal state
title Startable token
dev Standard Token modified startable transfers
Approves calls receiving contract
dev Function burn tokens
param burner address token holder
param value amount token burned
dev Burns specific amount tokens
param value amount token burned
* @dev Burns tokens one address
* @param address address want burn tokens
* @param value uint256 amount tokens burned
dev transfer token tx orgin specified address ( Authorized contract )
dev Burns specific amount tokens tx orgin ( Authorized contract )
param value amount token burned
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 179
github ethereum EIPs issues 20
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
Safe Math sub throw enough balance
Function called user another contract wants transfer funds
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
check budget allowed

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

title owned
title mortal
title DSMath
uint128 functions ( h half )
int256 functions
WAD math
title minter
title Pricer
title coin
title DSBase Actor
Copyright 2016 Nexus Development , LLC
Licensed Apache License , Version 2 0 ( "License" ) ;
may use file except compliance License
may obtain copy License
http : www apache org licenses LICENSE 2 0
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND , either express implied
See License specific language governing permissions
limitations License
dev Requests new Stati Coins made given address
param target ETH sent
param calldata
param value
return True ETH transfered
title Freeze
title one Write
dev Constuctor , make sure written=false initally
title pricer Control
dev Changes Pricer contract , certain delay
param new Address Allows coins created sent people
return transaction ID viewed pending mapping
title minter
dev Allows extra ETH added benefit types coin holders
return nothing
dev Requests new Stati Coins made sender
* cannot called contract simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
return transaction ID viewed pending mapping
dev Requests new Stati Coins made given address
* address cannot contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
param user Allows coins created sent people
return transaction ID viewed pending mapping
dev Requests new Riskcoins made sender
* cannot called contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
return transaction ID viewed pending mapping
dev Requests new Riskcoins made given address
* address cannot contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
param user Allows coins created sent people
return transaction ID viewed pending mapping
dev Returns Riskcoins Needs bit eth sent pay pricer contract excess returned
* address cannot contract , simple wallet ( 0 codesize )
param Quantity Amount coins returned
* @return transaction ID viewed pending mapping
dev Returns Stati Coins , Needs bit eth sent pay pricer contract
param Quantity Amount coins returned
* @return transaction ID viewed pending mapping
dev Returns total amount eth sent buy Stati Coins
* @return amount Eth
dev Returns total amount eth sent buy Stati Coins allows users test arbitrary amounts Risk Total ETH contained contract
* @param Risk Total Quantity riskcoins
param Total ETH Total value ETH contract
* @return amount Eth
dev Allows users query various hypothetical prices Risk Coins terms base currency
param current Price Current price ETH Base currency
param Static Total Total quantity Stati Coins issued
param Risk Total Total quantity invetor coins issued
param ETHTotal Total quantity ETH contract
return price Risk Coins
dev Allows users query price Risk Coins terms base currency , using current quantities coins
param current Price Current price ETH Base currency
* @return price Risk Coins
dev Allows users query last price Risk Coins terms base currency
return price Risk Coins
dev Returns ratio Riskcoin grows value equivalent growth ETH price
* @return ratio
dev Returns current price Risk price goes negative
* @return Risk price underlying per ETH
dev Allows minting fee changed , owner modify
param new Fee Size new fee
return nothing
dev Allows minting fee reduced , owner modify , Triggers pricer updated
param new Risk Address Riskcoin contract
param new Static Address Stati Coin contract
return nothing
dev Return function Pricer contract Controls melting minting new coins
param Trans ID Tranasction ID issued minter
param Price Quantity Base currency per ETH delivered Pricer contract
Nothing returned One 4 functions implemented
dev Internal function create new Stati Coins based transaction data Pending queue enough spare Stati Coins available ETH refunded
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , adds Stati Coins users address events created
dev Internal function create new Risk coins based transaction data Pending queue Risk coins created price zero
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , adds Riskcoins users address events created
dev Internal function Return Stati Coins based transaction data Pending queue Static returned time
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , removes Stati Coins user's address , sends ETH events created
dev Internal function Return Riskcoins based transaction data Pending queue Riskcoins returned long Risk price greater 0
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle Pricer contract
return function returns nothing , removes Stati Coins users address , sends ETH events created
* @dev checks address contract
* @param address check
* @return True contract ,
dev Requests coins melted ETH returned
* @param Quantity Static Risk coins melted0
* @param Amount ETH Amount eth sent contract cover oracle fee Excess returned
param user Address returned ETH sent
* @param action Allows Static Risk coins returned
* @return transaction ID viewed Pending mapping
dev Requests new coins made
param user Address coins created
param amount Amount eth sent contract
* @param action Allows Static Risk coins minted
* @return transaction ID viewed pending mapping
Copyright ( C ) 2015 , 2016 , 2017 Dapp Hub , LLC
Licensed Apache License , Version 2 0 ( "License" )
may use file except compliance License
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND ( express implied )
uint128 functions ( h half )
int256 functions
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens
www apache org licenses LICENSE 2 0
Copyright ( c ) 2017 Genki FS
Basically "break glass case emergency"
fixes price allows everyone redeem coins current value
becomes false ETH claimed pricer contract changed
Adds modifies allow one function called
Copyright ( c ) 2017 Genki FS
Copyright ( c ) 2017 Genki FS
Controls Pricer contract minter Allows updates made future swapping pricer contract
Although expected , web addresses , API's , new oracles could require adjusments pricer contract
delay 2 days implemented allow coinholders redeem coins agree new contract
new pricer contract unfreezes minter ( allowing live price used )
days updated coins set
log0 ( 'Updating' ) ;
Copyright ( c ) 2017 Genki FS
contract controller Stati Coin contracts
Users 4 ( +2 ) functions call mint melt Static Risk coins calls Pricer contract
delay Pricer contract call back Price Return ( ) function
call one functions Action New Static , Action New Risk , Action Ret Static , Action Ret Risk
call Static Risk ERC20 contracts mint melt new tokens
Transfer tokens handled ERC20 contracts , ETH stored
Enum users
Struct
Amount sent user ( either ETH number returned coins )
Address user
Type action requested ( mint melt Risk Stati Coin )
ID pricer function
Storage last price returned Pricer contract
Amount eth added contract
increasing counter keep track transactions requested
Last transaction removed
Name underlying base currency
ERC20 token interface Stati Coin
ERC20 token interface Risk coin
=15*10** ( 17 ) ; default ratio Risk price
0 5 plus multiplier defines maximum leverage
0 002 Used pay oricalize marketing contract parties interest
mapping pending transactions
Called ETH contract everything needs manually reset
, uint8 Decimal Places
CONSTRUCTOR
can't add new contracts gives gas messages much code
ETH sent address cannot determine Stati Coins Risk Coins , send back
log0 ( 'New Static' ) ;
log0 ( 'New Static' ) ;
log0 ( 'New Risk' ) ;
log0 ( 'New Risk' ) ;
Skip pricer contract
returned Risk price positive
log0 ( 'Ret Risk' ) ;
Skip pricer contract
Static returned time
log0 ( 'Ret Static' ) ;
Constant functions ( Ones write blockchain )
( Multiplier+lev Toll ) * Risk Total Total ETH
Return default price current Price * Multiplier
ETHTotal* current Price Static Total
Risk price positive
( ETHTotal * current Price ) Static Total ) Risk Total
Risk Price negative
balance Risk total Supply
Static total Supply balance
owner access following functions
Pricer access following function
Get details transaction
error pricing contract frozen , use old price
dont update coins missing
otherwise update last price
Mint new Stati Coins
Melt old Stati Coins
Mint new Risk coins
Melt old Risk coin
Remove transaction blockchain ( saving gas )
internal functions
log0 ( 'New Static' ) ;
( Action New Static details action ) {revert ( ) ;} already checked
Calculates amount ETH added create Stati Coins ( excluding amount already sent stored contract )
amount sent less Static amount available , everything fine Nothing needs returned
restrictions hamper creation Stati Coin
Amount Static less amount requested
Take Stati Coins available
Maybe zero Static available , returned
return ETH
Amount Mint = 0; required Risk price = 0
Static added Risk price positive leverage limit
Dont create Cur Risk Price 0 Static available ( leverage high )
log0 ( 'leverage OK' ) ;
request coins Static creator contract
Event giving holder address , coins created , transaction id , price
return money enough Stati Coins available
define blank `bytes`
Refund ETH contract
log0 ( 'New Risk' ) ;
( Action New Risk details action ) {revert ( ) ;} already checked
Get Risk price using amount ETH contract transaction existed
Riskcoins = details amount * Price Cur Risk Price
request coins Riskcoin creator contract
Event giving holder address , coins created , transaction id , price
create Cur Risk Price 0 , Return ETH originally sent
define blank `bytes`
( Action Ret Static details action ) {revert ( ) ;} already checked
log0 ( 'Ret Static' ) ;
Risk coins balance use fixed price
details amount Price
deducted first , add back Returning ETH goes wrong
enough ETH available Return Eth contract
define blank `bytes`
ETH returned successfully
error , add back amount previously deducted
Add back amount requested
redo creation event
( Action Ret Risk details action ) {revert ( ) ;} already checked
log0 ( 'Ret Risk' ) ;
( 0==Static total Supply ( ) ) { Price=last Price}; Stati Coins , Risk coins worth ETHReturned = details amount Risk Total * ETHTotal
details amount * Cur Risk Price Price
Coins deducted first , add back returning ETH goes wrong
never happen , case
define blank `bytes`
Returning ETH went ok
error , add back amount previously deducted Riskcoin contract
Risk price zero can't anything Call back delete transaction contract
Retrieve size code target address , needs assembly
Get cost querying pricer contract
log0 ( 'Not enough ETH mint' ) ;
Returning coins much ETH sent , return
quantity non zero
Ask pricer get price Fee also cover calling function Price Return later time
Add transaction Pending queue
return transaction ID user
Return ETH much sent cover pricer
fee maxium pricer query cost mint Fee% value sent
log0 ( 'Not enough ETH mint' ) ;
Ask pricer return price
Store transaction ID data ready later recall
return transaction ID contract user
Reset contract
delete current Static tokens
delete current Risk tokens
need create new coins externally , much gas used done
Reset write Lock Unwritten modifiers

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

price feed sol
Copyright ( C ) 2017 Dapp Hub , LLC
Licensed Apache License , Version 2 0 ( "License" )
may use file except compliance License
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND ( express implied )
famous algorithm called "exponentiation squaring"
calculates x^n x fixed point n regular unsigned
( log n ) , instead ( n ) naive repeated multiplication
facts works :
n even , x^n = ( x^2 ) ^ ( n 2 )
n odd , x^n = x * x^ ( n 1 ) ,
applying equation even x gives
x^n = x * ( x^2 ) ^ ( ( n 1 ) 2 )
Also , EVM division flooring
floor[ ( n 1 ) 2] = floor[n 2]

price feed sol
Copyright ( C ) 2017 Dapp Hub , LLC
Licensed Apache License , Version 2 0 ( "License" )
may use file except compliance License
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND ( express implied )
famous algorithm called "exponentiation squaring"
calculates x^n x fixed point n regular unsigned
( log n ) , instead ( n ) naive repeated multiplication
facts works :
n even , x^n = ( x^2 ) ^ ( n 2 )
n odd , x^n = x * x^ ( n 1 ) ,
applying equation even x gives
x^n = x * ( x^2 ) ^ ( ( n 1 ) 2 )
Also , EVM division flooring
floor[ ( n 1 ) 2] = floor[n 2]

price feed sol
Copyright ( C ) 2017 Dapp Hub , LLC
Licensed Apache License , Version 2 0 ( "License" )
may use file except compliance License
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND ( express implied )
famous algorithm called "exponentiation squaring"
calculates x^n x fixed point n regular unsigned
( log n ) , instead ( n ) naive repeated multiplication
facts works :
n even , x^n = ( x^2 ) ^ ( n 2 )
n odd , x^n = x * x^ ( n 1 ) ,
applying equation even x gives
x^n = x * ( x^2 ) ^ ( ( n 1 ) 2 )
Also , EVM division flooring
floor[ ( n 1 ) 2] = floor[n 2]

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
( C ) 2017 Token Market Ltd ( https : github Token Market Net ico blob master LICENSE txt ) Commit : ec1d834d44393d7a6c047eb6419df69da9a56b55
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

work controller functions
transfer controller functions
token controller functions
send ether function ( working )
ERC20 Interface

title owned
title mortal
title DSMath
uint128 functions ( h half )
int256 functions
WAD math
title minter
title Pricer
title coin
title DSBase Actor
Copyright 2016 Nexus Development , LLC
Licensed Apache License , Version 2 0 ( "License" ) ;
may use file except compliance License
may obtain copy License
http : www apache org licenses LICENSE 2 0
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND , either express implied
See License specific language governing permissions
limitations License
dev Requests new Stati Coins made given address
param target ETH sent
param calldata
param value
return True ETH transfered
title Freeze
title one Write
dev Constuctor , make sure written=false initally
title pricer Control
dev Changes Pricer contract , certain delay
param new Address Allows coins created sent people
return transaction ID viewed pending mapping
title minter
dev Allows extra ETH added benefit types coin holders
return nothing
dev Requests new Stati Coins made sender
* cannot called contract simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
return transaction ID viewed pending mapping
dev Requests new Stati Coins made given address
* address cannot contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
param user Allows coins created sent people
return transaction ID viewed pending mapping
dev Requests new Riskcoins made sender
* cannot called contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
return transaction ID viewed pending mapping
dev Requests new Riskcoins made given address
* address cannot contract , simple wallet ( 0 codesize )
* Contracts must use Approve , transfer pattern move coins wallets
param user Allows coins created sent people
return transaction ID viewed pending mapping
dev Returns Riskcoins Needs bit eth sent pay pricer contract excess returned
* address cannot contract , simple wallet ( 0 codesize )
param Quantity Amount coins returned
* @return transaction ID viewed pending mapping
dev Returns Stati Coins , Needs bit eth sent pay pricer contract
param Quantity Amount coins returned
* @return transaction ID viewed pending mapping
dev Returns total amount eth sent buy Stati Coins
* @return amount Eth
dev Returns total amount eth sent buy Stati Coins allows users test arbitrary amounts Risk Total ETH contained contract
* @param Risk Total Quantity
param Total ETH Total value ETH contract
* @return amount Eth
dev Allows users query various hypothetical prices Risk Coins terms base currency
param current Price Current price ETH Base currency
param Static Total Total quantity Stati Coins issued
param Risk Total Total quantity invetor coins issued
param ETHTotal Total quantity ETH contract
return price Risk Coins
dev Allows users query last price Risk Coins terms base currency
return price Risk Coins
dev Allows users query price Risk Coins terms base currency , using current quantities coins
param current Price Current price ETH Base currency
* @return price Risk Coins
dev Returns ratio Riskcoin grows value equivalent growth ETH price
* @return ratio
dev Returns current price Risk price goes negative
* @return Risk price underlying per ETH
dev Allows minting fee changed , owner modify
* Fee charged coin creation
param new Fee Size new fee
return nothing
dev owner modify , Triggers pricer updated
param new Risk Address Riskcoin contract
param new Static Address Stati Coin contract
return nothing
dev Return function Pricer contract Controls melting minting new coins
param Trans ID Tranasction ID issued minter
param Price Quantity Base currency per ETH delivered Pricer contract
Nothing returned One 4 functions implemented
dev Internal function create new Stati Coins based transaction data Pending queue enough spare Stati Coins available ETH refunded
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , adds Stati Coins users address events created
dev Internal function create new Risk coins based transaction data Pending queue Risk coins created price zero
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , adds Riskcoins users address events created
dev Internal function Return Stati Coins based transaction data Pending queue Static returned time
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle pricer contract
return function returns nothing , removes Stati Coins user's address , sends ETH events created
dev Internal function Return Riskcoins based transaction data Pending queue Riskcoins returned long Risk price greater 0
param details Structure holding amount sent ( ETH ) , address person sent , type request
param Trans ID ID transaction ( stored contract )
param Price Current 24 hour average price returned oracle Pricer contract
return function returns nothing , removes Risk Coins users address , sends ETH events created
* @dev checks address contract
* @param address check
* @return True contract ,
dev Requests coins melted ETH returned
* @param Quantity Static Risk coins melted
* @param Amount ETH Amount ETH sent contract cover oracle fee Excess returned
param user Address returned ETH sent
* @param action Allows Static Risk coins returned
* @return transaction ID viewed Pending mapping
dev Requests new coins made
param user Address coins created
param amount Amount eth sent contract
* @param action Allows Static Risk coins minted
* @return transaction ID viewed pending mapping
User interface http : www staticoin
Full source code https : github genkifs staticoin
Copyright ( C ) 2015 , 2016 , 2017 Dapp Hub , LLC
Licensed Apache License , Version 2 0 ( "License" )
may use file except compliance License
Unless required applicable law agreed writing , software
distributed License distributed "AS IS" BASIS ,
WITHOUT WARRANTIES CONDITIONS KIND ( express implied )
uint128 functions ( h half )
int256 functions
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens
www apache org licenses LICENSE 2 0
Copyright ( c ) 2017 Genki FS
Basically "break glass case emergency"
fixes price allows everyone redeem coins current value
becomes false ETH claimed pricer contract changed
Adds modifies allow one function called
Copyright ( c ) 2017 Genki FS
Copyright ( c ) 2017 Genki FS
Controls Pricer contract minter Allows updates made future swapping pricer contract
Although expected , web addresses , API's , new oracles could require adjusments pricer contract
delay 2 days implemented allow coinholders redeem coins agree new contract
new pricer contract unfreezes minter ( allowing live price used )
days updated coins set
log0 ( 'Updating' ) ;
Copyright ( c ) 2017 Genki FS
contract controller Stati Coin contracts
Users 4 ( +2 ) functions call mint melt Static Risk coins calls Pricer contract
delay Pricer contract call back Price Return ( ) function
call one functions Action New Static , Action New Risk , Action Ret Static , Action Ret Risk
call Static Risk ERC20 contracts mint melt new tokens
Transfer tokens handled ERC20 contracts , ETH stored
Enum users
Struct
Amount sent user ( either ETH number returned coins )
Address user
Type action requested ( mint melt Risk Stati Coin )
ID pricer function
Storage last price returned Pricer contract
increasing counter keep track transactions requested
Name underlying base currency
ERC20 token interface Stati Coin
ERC20 token interface Risk coin
=15*10** ( 17 ) ; default ratio Risk price
0 5 plus multiplier defines maximum leverage
0 002 Used pay oricalize marketing contract parties interest
mapping pending transactions
Called ETH contract everything needs manually reset
, uint8 Decimal Places
CONSTRUCTOR
can't add new contracts gives gas messages much code
ETH sent address cannot determine Stati Coins Risk Coins , send back
log0 ( 'New Static' ) ;
log0 ( 'New Static' ) ;
log0 ( 'New Risk' ) ;
log0 ( 'New Risk' ) ;
Skip pricer contract
returned Risk price positive
log0 ( 'Ret Risk' ) ;
Skip pricer contract
Static returned time
log0 ( 'Ret Static' ) ;
Constant functions ( Ones write blockchain )
( Multiplier+lev Toll ) * Risk Total Total ETH
Return default price current Price * Multiplier
ETHTotal* current Price Static Total
Risk price positive
( ETHTotal * current Price ) Static Total ) Risk Total
Risk Price negative
balance Risk total Supply
Static total Supply balance
owner access following functions
Pricer access following function
Get details transaction
error pricing contract frozen , use old price
dont update coins missing
otherwise update last price
Mint new Stati Coins
Melt old Stati Coins
Mint new Riskcoins
Melt old Riskcoins
Remove transaction blockchain ( saving gas )
internal functions
log0 ( 'New Static' ) ;
( Action New Static details action ) {revert ( ) ;} already checked
Calculates amount ETH added create Stati Coins ( excluding amount already sent stored contract )
amount sent less Static amount available , everything fine Nothing needs returned
restrictions hamper creation Stati Coin
Amount Static less amount requested
Take Stati Coins available
Maybe zero Static available , returned
return ETH
Amount Mint = 0; required Risk price = 0
Static added Risk price positive leverage limit
Dont create Cur Risk Price 0 Static available ( leverage high )
log0 ( 'leverage OK' ) ;
request coins Static creator contract
Event giving holder address , coins created , transaction id , price
return money enough Stati Coins available
define blank `bytes`
Refund ETH contract
log0 ( 'New Risk' ) ;
( Action New Risk details action ) {revert ( ) ;} already checked
Get Risk price using amount ETH contract transaction existed
Riskcoins = details amount * Price Cur Risk Price
request coins Riskcoin creator contract
Event giving holder address , coins created , transaction id , price
create Cur Risk Price 0 , Return ETH originally sent
define blank `bytes`
( Action Ret Static details action ) {revert ( ) ;} already checked
log0 ( 'Ret Static' ) ;
Risk coins balance use fixed price
details amount Price
deducted first , add back Returning ETH goes wrong
enough ETH available Return Eth contract
define blank `bytes`
ETH returned successfully
error , add back amount previously deducted
Add back amount requested
redo creation event
( Action Ret Risk details action ) {revert ( ) ;} already checked
log0 ( 'Ret Risk' ) ;
Stati Coins , Risk coins worth , ETHReturned = details amount Risk Total * ETHTotal
details amount * Cur Risk Price Price
Coins deducted first , add back returning ETH goes wrong
never happen , case
define blank `bytes`
Returning ETH went ok
error , add back amount previously deducted Riskcoin contract
Risk price zero can't anything Call back delete transaction contract
Retrieve size code target address , needs assembly
Get cost querying pricer contract
log0 ( 'Not enough ETH mint' ) ;
Returning coins much ETH sent , return
quantity non zero
Ask pricer get price Fee also cover calling function Price Return later time
Add transaction Pending queue
return transaction ID user
Return ETH much sent cover pricer
fee maxium pricer query cost mint Fee% value sent
log0 ( 'Not enough ETH mint' ) ;
Ask pricer return price
Store transaction ID data ready later recall
return transaction ID contract user
Reset contract
delete current Static tokens
delete current Risk tokens
need create new coins externally , much gas used done
Reset write Lock Unwritten modifiers

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
* @dev Transfer tokens one address another Requires allowance set
* set can't changed ( minter contract change Owner function )
* @param minter Address minter contract
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
* @dev Transfer tokens one address another Requires allowance set
* set can't changed ( minter contract change Owner function )
* @param minter Address minter contract
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

* @dev Checks short addresses
* @param numwords number parameters passed
* @dev validates address
* @param address checks null contract address
* @dev Transfer tokens msg sender another address
* Cannot Allows execution transfer address code size 0
* @param address address check contract
* @dev Transfer tokens msg sender another address
* Cannot used send tokens contract , means contracts cannot mint coins
* Contracts use approve transfer method
* based https : github Dexaran ERC223 token standard
* @param address address coin transfered
* @param value uint256 amount tokens transferred
* @dev Transfer tokens one address another Requires allowance set
* @param address address want send tokens
* @param address address want transfer
* @param value uint256 amount tokens transferred
* @dev returns amount given account
* @param owner address queried
* @return Balance owner
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
* @dev allows queries much given address allowed spend behalf another account
* @param owner address address owns funds
* @param spender address address spend funds
* @return remaining uint256 specifying amount tokens still available spender
* @dev Allows increment allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param added Value amount increase alowance
* @return True allowance increased
* @dev Allows decrement allowed value
* better use function avoid 2 calls
* @param spender address address spend funds
* @param subtracted Value amount decrease allowance
* @return True allowance decreased
Approves calls receiving contract additional paramteres
* @dev Approves calls receiving contract additional paramteres
* @param owner address address owns funds
* @param spender address address spend funds
* @param value address address spend funds
* @param extra Data additional paramters passed
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address receive funds
* @param minted Amount amount funds sent
* @param owner contract responsable controling amount funds
* @return True successful
* @dev Approves calls receiving contract additional paramteres
* @param target address address return funds
* @param melted Amount amount funds returned
* @param owner contract responsable controling amount funds
* @return True successful
title Standard Token
title Coin
* @dev Transfer tokens one address another Requires allowance set
* set can't changed ( minter contract change Owner function )
* @param minter Address minter contract
title Risk Coin
dev direct ETH sent Risk Coin address minter New Risk function
title Stati Coin
dev direct ETH sent Stati Coin address minter New Static function
title coin
title minter
https : github genkifs staticoin
Inspired https : blog aragon one library driven development solidity 2bebcaf88736
Retrieve size code target address , needs assembly
github Dexaran ERC223 token standard
require user set zero resetting nonzero
require user set zero resetting nonzero
call receive Approval function contract want notified
crafts function signature manually one include contract
assumed call *should* succeed , otherwise one would use vanilla approve instead
balances[target] += minted Amount;
total Supply += minted Amount;
Deliver coin mint
mint delivers address
balances[target] = melted Amount;
total Supply = melted Amount;
address delivers minter
minter delivers coin burn address
Long token name
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
mintable coin zero inital supply ( fall back zero )
Minter interface
Set name display purposes
Set symbol display purposes
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
@return total amount tokens

Copyright ( c ) 2015 2016 Oraclize SRL
Copyright ( c ) 2016 Oraclize LTD
Permission hereby granted , free charge , person obtaining copy
software associated documentation files ( "Software" ) , deal
Software without restriction , including without limitation rights
use , copy , modify , merge , publish , distribute , sublicense , sell
copies Software , permit persons Software
furnished , subject following conditions :
copyright notice permission notice shall included
copies substantial portions Software
SOFTWARE PROVIDED "AS IS" , WITHOUT WARRANTY KIND , EXPRESS
IMPLIED , INCLUDING LIMITED WARRANTIES MERCHANTABILITY ,
FITNESS PARTICULAR PURPOSE NONINFRINGEMENT EVENT SHALL
AUTHORS COPYRIGHT HOLDERS LIABLE CLAIM , DAMAGES
LIABILITY , WHETHER ACTION CONTRACT , TORT OTHERWISE , ARISING ,
CONNECTION SOFTWARE USE DEALINGS
SOFTWARE
title String & slice utility library Solidity contracts
Nick Johnson [email protected]
dev Functionality library largely implemented using
abstraction called 'slice' slice represents part string
anything entire string single character , even
characters ( 0 length slice ) Since slice specify
offset length , copying manipulating slices lot less
expensive copying manipulating strings reference
reduce gas costs , functions slice need return
slice modify original one instead allocating new one;
instance , `s split ( " " ) ` return text first ' ' ,
modifying contain remainder string ' '
situations want modify original slice ,
make copy first ` copy ( ) ` , example :
`s copy ( ) split ( " " ) ` Try avoid using idiom loops; since
Solidity memory management , result allocating many
short lived slices later discarded
Functions return two slices come two versions : non allocating
version takes second slice argument , modifying
place , allocating version allocates returns second
slice; see `next Rune` example
Functions copy string data return strings rather
slices; cast back slices processing
required
convenience , functions provided non modifying
variants create new slice return both; instance ,
`s split New ( ' ' ) ` leaves unmodified , returns two values
corresponding left right parts string
dev Returns slice containing entire string
param self string make slice
return newly allocated slice containing entire string
dev Returns length null terminated bytes32 string
param self value find length
return length string , 0 32
dev Returns slice containing entire bytes32 , interpreted
null termintaed utf 8 string
param self bytes32 value convert slice
return new slice containing value input argument
first null
dev Returns new slice containing data current slice
param self slice copy
return new slice containing data `self`
dev Copies slice new string
param self slice copy
return newly allocated string containing slice's text
dev Returns length runes slice Note operation
takes time proportional length slice; avoid using
loops , call `slice empty ( ) ` need know whether
slice empty
param self slice operate
return length slice runes
dev Returns true slice empty ( length 0 )
param self slice operate
return True slice empty , False otherwise
dev Returns positive number `other` comes lexicographically
`self` , negative number comes , zero
contents two slices equal Comparison done per rune ,
unicode codepoints
param self first slice compare
param second slice compare
return result comparison
dev Returns true two slices contain text
param self first slice compare
param self second slice compare
return True slices equal , false otherwise
dev Extracts first rune slice `rune` , advancing
slice point next rune returning `self`
param self slice operate
param rune slice contain first rune
return `rune`
dev Returns first rune slice , advancing slice point
next rune
param self slice operate
return slice containing first rune `self`
dev Returns number first codepoint slice
param self slice operate
return number first codepoint slice
dev Returns keccak 256 hash slice
param self slice hash
return hash slice
dev Returns true `self` starts `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` starts `needle` , `needle` removed
beginning `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Returns true slice ends `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` ends `needle` , `needle` removed
end `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Modifies `self` contain everything first occurrence
`needle` end slice `self` set empty slice
`needle` found
param self slice search modify
param needle text search
return `self`
dev Modifies `self` contain part string start
`self` end first occurrence `needle` `needle`
found , `self` set empty slice
param self slice search modify
param needle text search
return `self`
dev Splits slice , setting `self` everything first
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything first
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` first occurrence `delim`
dev Splits slice , setting `self` everything last
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything last
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` last occurrence `delim`
dev Counts number nonoverlapping occurrences `needle` `self`
param self slice search
param needle text search `self`
return number occurrences `needle` found `self`
dev Returns True `self` contains `needle`
param self slice search
param needle text search `self`
return True `needle` found `self` , false otherwise
dev Returns newly allocated string containing concatenation
`self` `other`
param self first slice concatenate
param second slice concatenate
return concatenation two strings
dev Joins array slices , using `self` delimiter , returning
newly allocated string
param self delimiter use
param parts list slices join
return newly allocated string containing slices `parts` ,
joined `self`
checks player profit , bet size player number within range
checks game currently active
checks payouts currently active
checks Oraclize address calling
checks owner address calling
checks treasury address calling
game vars
player vars
events
log bets + output web3 precise 'payout win' field UI
output web3 UI bet result
Status : 0=lose , 1=win , 2=win + failed send , 3=refund , 4=refund + failed send
log manual refunds
log owner transfers
init
use TLSNotary oraclize call
init 990 = 99% ( 1% house Edge )
init 10 , 000 = 1%
init min bet ( 0 1 ether )
init gas oraclize
public function
player submit bet
game active & bet valid query oraclize set player vars
assign partially encrypted query oraclize
api Key encrypted
integer query plain text
map bet id oraclize query
map player lucky number oraclize query
map value wager oraclize query
map player address oraclize query
safely map player profit oraclize query
safely increase max Pending Payouts liability calc pending payouts assumption win
check contract payout win
provides accurate numbers web3 allows manual refunds case oraclize callback
semi public function oraclize call
TLSNotary oraclize call
player address mapped query id exist
keep oraclize honest retrieving serial Number random org result
map result player
get player Address query id
delete player Address query id
map player Profit query id
set player Profit query id 0
safely reduce max Pending Payouts liability
map player Bet Value query id
set player Bet Value query id 0
total number bets
total wagered
refund
result 0 result empty proof refund original bet value
refund fails save refund value player Pending Withdrawals
send refund external call untrusted contract
send fails map refund value player Pending Withdrawals[address]
withdrawal later via player Withdraw Pending Transactions
send failed let player withdraw via player Withdraw Pending Transactions
pay winner
update contract balance calculate new max bet
send reward
send reward fails save value player Pending Withdrawals
safely reduce contract balance player profit
update total wei
safely calculate payout via profit plus original wager
update maximum profit
send win external call untrusted contract
send fails map reward value player Pending Withdrawals[address]
withdrawal later via player Withdraw Pending Transactions
send failed let player withdraw via player Withdraw Pending Transactions
win
send 1 wei losing bet
update contract balance calculate new max bet
safe adjust contract Balance
set Max Profit
send 1 wei losing bet
update maximum profit
send 1 wei external call untrusted contract
send failed let player withdraw via player Withdraw Pending Transactions
public function
case failed refund win send
external call untrusted contract
send failed revert player Pending Withdrawals[msg sender] = 0;
player try withdraw later
check pending withdrawals
internal function
sets max profit
owner treasury address functions
safely update contract balance
update maximum profit
set gas oraclize query
owner adjust contract balance variable ( used max profit calc )
owner address set house Edge
owner address set max Profit Percent House
restrict bet maximum profit 1% contract Balance
owner address set min Bet
owner address transfer ether
safely update contract balance sending funds
update max profit
owner address manual refund
used bet placed + oraclize failed callback
filter Log Bet address player Bet Id :
Log Bet ( player Bet Id[rng Id] , player Address[rng Id] , safe Add ( player Bet Value[rng Id] , player Profit[rng Id] ) , player Profit[rng Id] , player Bet Value[rng Id] , player Number[rng Id] ) ;
check following logs exist player Bet Id player Address[rng Id] refunding :
Log Result Log Refund
Log Result exists player use withdraw pattern player Withdraw Pending Transactions
safely reduce pending Payouts player Profit[rng Id]
send refund
log refunds
owner address set emergency pause 1
owner address set emergency pause 2
owner address set treasury address
owner address set owner address
owner address suicide emergency
ORACLIZE API
mainnet
ropsten testnet
kovan testnet
rinkeby testnet
ethereum bridge
ether camp ide
browser solidity
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
parse Int
parse Int ( parse Float*10^ b )
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
Step 6 : verify attestation signature , APPKEY1 must sign session Key correct ledger app ( CODEHASH )
role
Step 7 : verify APPKEY1 provenance ( must signed Ledger )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 2 : unique keyhash match sha256 ( context name + query Id )
Step 3 : assume sig1 valid ( verified step 5 ) verify 'result' prefix sha256 ( sig1 )
Step 4 : commitment match verification , sha3 ( delay , nbytes , unonce , session Key Hash ) == commitment storage
verify computed args match ones specified query
unonce , nbytes session Key Hash match
Step 5 : validity verification sig1 ( keyhash args signed session Key )
verify session Pubkey Hash verified already , let's !
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Buffer small
better way ?
NOTE : offset 32 added skip `size` field bytes variables
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Duplicate Solidity's ecrecover , catching CALL return value
memory management Solidity uses memory offset
0x40 store current end memory write past (
writes memory extensions ) , update offset
Solidity reuse memory used needed
context
FIXME : inline assembly can't access return values
NOTE : reuse request memory deal
return code
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
signature format compact form :
{bytes32 r}{bytes32 s}{uint8 v}
Compact means , uint8 padded 32 bytes
loading last 32 bytes exploit fact
'mload' pad zeroes overread
'mload8' , would nicer
Alternative solution :
'byte' working due Solidity parser , lets
use second best option , 'and'
v : = ( mload ( add ( sig , 65 ) ) , 255 )
albeit non transactional signatures specified YP , one would expect
match YP range [27 , 28]
geth uses [0 , 1] clients followed might change , see :
https : github ethereum go ethereum issues 2053
ORACLIZE API
Copy word length chunks possible
Copy remaining bytes
Allocate space `self` memory , copy , point ret
Starting ptr 31 means LSB byte care
Mask irrelevant bytes check
Load first byte rune LSBs b
Check truncated codepoints
Load rune MSBs b
Check truncated codepoints
Invalid UTF 8 sequence
Returns memory address first byte first occurrence
`needle` `self` , first byte `self` found
Optimized assembly 68 gas per byte short strings
long needles , use hashing
Returns memory address first byte last occurrence
`needle` `self` , address `self` found
Optimized assembly 69 gas per byte short strings
long needles , use hashing
found
found
init discontinued contract data
todo
init discontinued contract data
todo
init discontinued contract data
todo
todo update encrypted query
api random org json rpc 1 invoke ) result random[\"serial Number\" , \"data\"]' , '\\n{\"jsonrpc\" : \"2 0\" , \"method\" : \"generate Signed Integers\" , \"params\" : {\"api Key\" : ${[decrypt] BP+K1l KZn LQr FNq P8p Pqiy Idp Vw Bw MX1X1 Xm JXj Zhj Qe R+q7Tjbxlkcv4Z3Gdb Te X8q4FZBAo0h LZ77Bl Tf SHhj Kc Qk gp DIz IG7UTQ+BWpze OBJGAE67R+s M03bsi Sdt0VRVe2Vn ATN3JVMw Nrm2E3S09zu4=} , \"n\" : 1 , \"min\" : 1 , \"max\" : 100 , \"replacement\" : true , \"base\" : 10${[identity] \"}\"} , \"id\" : 1${[identity] \"}\"}']" , gas Oraclize ) ;

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Contract working ERC223 tokens
New ERC23 contract interface
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
Function access name token
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

New ERC23 contract interface
Contract working ERC223 tokens
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
ERC23 token Dexaran
https : github Dexaran ERC23 tokens
https : github Lykke City Ethereum Api Dot Net Core blob master src Contract Builder contracts token Safe Math sol
github Dexaran ERC23 tokens
github Lykke City Ethereum Api Dot Net Core blob master src Contract Builder contracts token Safe Math sol *
Function access name token
Function access symbol token
Function access decimals token
Function access total supply tokens
Function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

coin multiplier
@title Constructor
@title Destructor
@title Contract enabler
@title Contract disabler
@title Contract proxy setter
@title Contract payment function
@title Sender funds getter
@title Universal call

ICO Syndicate Contract
Buys ICO Tokens given ICO known contract address
Author : Bogdan
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Emergency kill switch case critical bug found
Maximum amount user ETH contract accept Reduces risk hard cap related failure
developer address
crowdsale address Settable developer
token address Settable developer
Allows developer set crowdsale token addresses
allow developer set sale token addresses
allow setting addresses
Set crowdsale token addresses
Allows developer anyone password shut everything except withdrawals emergencies
activate kill switch sender developer password correct
Irreversibly activate kill switch
Withdraws ETH deposited tokens purchased given user rewards caller
allow withdrawals contract chance buy
Short circuit save gas user balance
contract failed buy sale , withdraw user's ETH
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Withdraw user's tokens contract purchased
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
Send funds Throws failure prevent loss funds
Buys tokens crowdsale rewards caller , callable anyone
Short circuit save gas contract already bought tokens
Short circuit save gas kill switch active
Disallow buying developer set sale address yet
Record contract bought tokens
Record amount ETH sent contract's current value
Transfer funds crowdsale address buy tokens
Throws crowdsale started yet already completed , preventing loss funds
Default function Called user sends ETH contract
Disallow deposits kill switch active
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

ICO Syndicate Contract
Buys ICO Tokens given ICO known contract address
Author : Bogdan
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Emergency kill switch case critical bug found
Maximum amount user ETH contract accept Reduces risk hard cap related failure
developer address
crowdsale address Settable developer
token address Settable developer
Allows developer set crowdsale token addresses
allow developer set sale token addresses
allow setting addresses
Set crowdsale token addresses
Allows developer anyone password shut everything except withdrawals emergencies
activate kill switch sender developer password correct
Irreversibly activate kill switch
Withdraws ETH deposited tokens purchased given user rewards caller
allow withdrawals contract chance buy
Short circuit save gas user balance
contract failed buy sale , withdraw user's ETH
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Withdraw user's tokens contract purchased
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
Send funds Throws failure prevent loss funds
Buys tokens crowdsale rewards caller , callable anyone
Short circuit save gas contract already bought tokens
Short circuit save gas kill switch active
Disallow buying developer set sale address yet
Record contract bought tokens
Record amount ETH sent contract's current value
Transfer funds crowdsale address buy tokens
Throws crowdsale started yet already completed , preventing loss funds
Default function Called user sends ETH contract
Disallow deposits kill switch active
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
name contract whatever like
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 STOAR = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
CHANGE VALUES TOKEN
make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Give creator initial tokens ( 100000 example )
Update total supply ( 100000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amout tokens transfered
dev Aprove passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifing amount tokens still avaible spender
dev Function mint tokens
param address recieve minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

slight change ERC20 base standard
function total Supply ( ) constant returns ( uint256 supply ) ;
replaced :
uint256 public total Supply;
automatically creates getter function total Supply
moved base contract since public getter functions
currently recognised implementation matching abstract
function compiler
EROSCOINToken Math operations safety checks avoid unnecessary conflicts
dev Ownable constructor sets original `owner` contract sender
account
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
EROSCOIN Token contract based full ERC 20 Token standard
https : github ethereum EIPs issues 20
Smartcontract EROSCOIN , information visit https : eroscoin org
Symbol : ERO
Status : ERC20 Verified
total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Saftey Checks Multiplication Tasks
Saftey Checks Divison Tasks
Saftey Checks Subtraction Tasks
Saftey Checks Addition Tasks
validates address currently checks null
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
Check allowance
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
github ethereum EIPs issues 20 issuecomment 263524729 *
Notify anyone listening approval done
many decimals show
240 million tokens , 8 decimal places
fancy name : eg EROSCOIN
identifier : eg ERO
Version 1 1 5 standard arbitrary versioning scheme
Give creator initial tokens
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

slight change ERC20 base standard
function total Supply ( ) constant returns ( uint256 supply ) ;
replaced :
uint256 public total Supply;
automatically creates getter function total Supply
moved base contract since public getter functions
currently recognised implementation matching abstract
function compiler
EROSToken Math operations safety checks avoid unnecessary conflicts
dev Ownable constructor sets original `owner` contract sender
account
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
EROSCOIN Token contract based full ERC 20 Token standard
https : github ethereum EIPs issues 20
Symbol : ERO
Status : ERC20 Verified
total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Saftey Checks Multiplication Tasks
Saftey Checks Divison Tasks
Saftey Checks Subtraction Tasks
Saftey Checks Addition Tasks
validates address currently checks null
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
Check allowance
Check sender enough
allow 0value transfer
Prevent transfer 0x0 address
Check overflows
mitigates ERC20 short address attack
things necesary
github ethereum EIPs issues 20 issuecomment 263524729 *
Notify anyone listening approval done
many decimals show
240 million tokens , 8 decimal places
fancy name : eg EROSCOIN
identifier : eg ERO
Version 1 1 5 standard arbitrary versioning scheme
Give creator initial tokens
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Enjin ICO group buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
Use caution use withdraw function trust
contract's token setting use ,
put wrong token address burn Enjin contract
handles withdrawal refunds Also works partial refunds
might getting full refund partial refund go limit Enjin's multisig wallet
assured CTO refund would
come pre sale wallet

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Edgeless blackjack contract allows calls authorized casino proxy contracts
proxy contract forward moves called authorized wallet owned Edgeless casino , game
data signed player show approval way , Edgeless provide fluid game experience
without wait transaction confirmations
: Julia Altenried
minimum bet
maximum bet
tells address authorized call game functions
notify listeners error occurred
constructur initialize contract initial values
param min Bet minimum bet
max Bet maximum bet
allows owner change minimum bet
param new Min new minimum bet
allows owner change maximum bet
param new Max new maximum bet
authorize address call game functions
param addr address authorized
deauthorize address call game functions
param addr address deauthorized
checks address authorized call game functionality
hash ( partial ) deck
hash casino seed used randomness generation deck hashing , also serves id
player address
bet
value cards : Ace , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , J , Q , K Ace 1 11 , course
value card determined looking card Values[card Id%13]
use game id reference games
list splits per game length 0 cases
tells hand given game doubled
tells player already claimed win
notify listeners new round blackjack started
notify listeners game outcome
notify listeners player doubled
notify listeners player split
constructur initialize contract minimum bet signer address
param min Bet minimum bet
max Bet maximum bet
bankroll lower bound profit sharing
lottery Address address lottery contract
profit Address address send 60% profit payday
initializes round blackjack id , hash ( partial ) deck hash server seed
accepts bet
throws exception bet low game given id already exists
param player address player
value value bet tokens
deck hash deck
srv Seed hash server seed
c Seed plain client seed
doubles bet game given id correct amount sent player double hand yet
param id game id
hand index hand doubled
value number tokens sent player
splits hands game given id correct amount sent player address player
split yet
param id game id
hand index hand split
value number tokens sent player
surrendering half bet returned player
send plain server seed check correct
param seed server seed
first checks deck player's number cards correct , checks player , sends win
param deck partial deck
seed plain server seed
num Cards number cards per hand
checks game given id already exists
param id game id
check deck casino seed correct
param game Id game id
deck partial deck
seed server seed
return true correct
converts uint8 array bytes
param byte Array uint8 array converted
return bytes
determines outcome game returns win
case loss , win 0
param game Id id game
cards cards partial deck
num Cards number cards per hand
return total win hands
calculates value player's hands
param cards holds ( partial ) deck
num Cards number cards per player hand
p Splits player's splits ( hand index )
return values player's hands
recursively plays player's hands
param h Index hand index
c Index index next card draw
Index index next split ,
player Values values player's hands ( yet complete )
cards holds ( partial ) deck
num Cards number cards per player hand
p Splits array splits
return values player's hands current card index
calculates value dealer's hand
param cards holds ( partial ) deck
num Cards number cards player holds
return value dealer's hand flag indicating dealer got blackjack
sums given numbers
note : player always hold less 100 cards
param numbers numbers sum
return sum numbers
throw game id already exists later maybe throw game id still running
seed incorrect first condition already fail
bust value 21
player blackjack dealer blackjack
pay 3 2
player wins regularly
tie
player looses
dealer always receives second forth card
2 aces , count 12
take cards value reaches 17

Edgeless Casino Proxy Contract Serves proxy game functionality
Allows players deposit withdraw funds
Allows authorized addresses make game transactions
: Julia Altenried
total balance players 4 virtual decimals
balance per player edgeless tokens 4 virtual decimals
case user wants needs call withdraw function wallet , first needs request withdrawal
price per kgas tokens ( 4 decimals )
edgeless token contract
owner able close contract nobody using least 30 days
informs listeners many tokens deposited player
informs listeners many tokens withdrawn player receiver address
* accepts deposits arbitrary address
* retrieves tokens message sender adds balance specified address
* edgeless tokens decimals , represented contract 4 decimals
* @param receiver address receiver
* num Tokens number tokens deposit ( 0 decimals )
* charge Gas indicates gas cost subtracted user's edgeless token balance
* user wants needs withdraw funds , needs request withdrawal first
* method sets earliest possible withdrawal date 7 minutes
* Reason : user able withdraw funds , last game methods yet mined
* case user requested withdrawal changes mind
* Necessary able continue playing
* withdraws amount user balance 7 minutes passed since request
* @param amount amount tokens withdraw
* lets owner withdraw bankroll
* @param num Tokens number tokens withdraw ( 0 decimals )
* returns current bankroll tokens 0 decimals
* lets owner close contract player funds nobody using least 30 days
* case close called accidentally
* make sure contract process closed
* delays time closing
indicates address authorized call game functions
list casino game contract addresses
number count withdrawal signatures ensure signature different even withdrawing amount address
* creates new casino wallet
* @param authorized Address address may send transactions Edgeless Casino
* blackjack Address address Edgeless blackjack contract
* token Contract address Edgeless token contract
* shifts tokens contract balance receiver
* callable edgeless casino contract
* @param receiver address receiver
* num Tokens amount tokens shift 4 decimals
* transfers amount contract balance owner's wallet
* @param receiver receiver address
* amount amount tokens withdraw ( 0 decimals )
* v , r , signature player
* update casino game address case new contract new casino game
* @param game index game
* new Address new address game
* authorize address call game functions
* @param addr address authorized
* deauthorize address call game functions
* @param addr address deauthorized
* updates price per 1000 gas EDG
* @param price new gas price ( 4 decimals , max 0 0256 EDG )
* Forwards move corresponding game contract data signed client
* casino contract ensures duplicate move
* @param game specifies game contract call
* value value send contract tokens 4 decimals
* data function call
* v , r , player's signature data
internals
make sure , casino always pay player

slight change ERC20 base standard
function total Supply ( ) constant returns ( uint256 supply ) ;
replaced :
uint256 public total Supply;
automatically creates getter function total Supply
moved base contract since public getter functions
currently recognised implementation matching abstract
function compiler
EROSToken Math operations safety checks avoid unnecessary conflicts
dev Ownable constructor sets original `owner` contract sender
account
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
EROSCOIN Alpha contract based full ERC 20 Token standard
https : github ethereum EIPs issues 20
Symbol : ERO
Status : ERC20 Verified
total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Saftey Checks Multiplication Tasks
Saftey Checks Divison Tasks
Saftey Checks Subtraction Tasks
Saftey Checks Addition Tasks
validates address currently checks null
github ethereum EIPs issues 20 issuecomment 263524729 *
Notify anyone listening approval done
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 TTC = 980 base units like comparing 1 wei 1 ether
2 4 billion tokens , 8 decimal places
fancy name : eg EROSCOIN Alpha
identifier : eg ERO
Version 0 1 6 standard arbitrary versioning scheme
Give creator initial tokens
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Original : Cintix
Modified : Moonlambos , yakois
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Maximum amount user ETH contract accept
minimum amount ETH must deposited buy performed
owner's address
crowdsale address verified : https : request network presale
Constructor Sets sender owner contract
Allows user withdraw tokens
Token's ERC20 address argument unknow time deployement
Tokens must bought
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
Send funds Throws failure prevent loss funds
Allows caller get eth refunded
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Buy tokens Sends ETH presale wallet records ETH amount held contract
allow owner perform buy
Short circuit save gas contract already bought tokens
pre sale address set
Throw contract balance less minimum required amount
Record contract bought tokens
Record amount ETH sent contract's current value
Transfer funds crowdsale address
owner raise cap
Raise cap
Default function Called user sends ETH contract
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Math operations safety checks
Functions modifier executed owner
Constructor
default function crowdfunding
Contract execute
Withdraw money contract balance owner
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

User get card ( titanium , black , gold metal , gold ) , amount eth sufficient
Math operations safety checks
Functions modifier executed owner
Constructor
default function crowdfunding
( cap + msg value cap max ) throw;
Contract execute
Update operations
Withdraw money contract balance owner
get total titanium cards
get total black cards
get total metal cards
get total gold cards
get total blue cards
get total start cards
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

User get card ( titanium , black , gold metal , gold ) , amount eth sufficient
Math operations safety checks
Functions modifier executed owner
Constructor
default function crowdfunding
( cap + msg value cap max ) throw;
Contract execute
Update operations
Withdraw money contract balance owner
get total titanium cards
get total black cards
get total metal cards
get total gold cards
get total blue cards
get total start cards
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

Original : Cintix
Modified : Moonlambos , yakois
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Maximum amount user ETH contract accept
minimum amount ETH must deposited buy performed
developer address
crowdsale address Settable owner
token address Settable owner
Constructor Sets sender owner contract
Allows owner set crowdsale token addresses
allow owner set sale token addresses
allow setting addresses
Set crowdsale token addresses
Allows user withdraw tokens
Tokens must bought
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
Send funds Throws failure prevent loss funds
Allows caller get eth refunded
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Buy tokens Sends ETH presale wallet records ETH amount held contract
Short circuit save gas contract already bought tokens
pre sale address set
Throw contract balance less minimum required amount
Record contract bought tokens
Record amount ETH sent contract's current value
Transfer funds crowdsale address
owner raise cap
Raise cap
Default function Called user sends ETH contract
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

User get card ( titanium , black , gold metal , gold ) , amount eth sufficient
Math operations safety checks
Functions modifier executed owner
Constructor
default function crowdfunding
Contract execute
Update operations
Withdraw money contract balance owner
get total titanium cards
get total black cards
get total metal cards
get total gold cards
get total blue cards
get total start cards
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold

Enjin ICO group buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
Use caution use withdraw function trust
contract's token setting use ,
put wrong token address burn Enjin contract
handles withdrawal refunds Also works partial refunds
might getting full refund partial refund go limit Enjin's multisig wallet
assured CTO refund would
come pre sale wallet

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Enjin ICO group buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
function called unfortunate case Enjin refund different address
Use caution use withdraw function trust
contract's token setting use ,
put wrong token address burn Enjin contract
might getting refund Enjin's multisig wallet
could also someone missed buy , keep
track well safely withdraw
might get Enjin refund another wallet ,
allow behavior

Enjin ICO group buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
function called unfortunate case Enjin refund different address
Use caution use withdraw function trust
contract's token setting use ,
put wrong token address burn Enjin contract
might getting refund Enjin's multisig wallet
could also someone missed buy , keep
track well safely withdraw
might get Enjin refund another wallet ,
allow behavior

Enjin ICO group buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
function called unfortunate case Enjin refund different address
allow crowdsale withdraw funds back ( anyone behalf )
might getting refund Enjin's multisig wallet
could also someone missed buy , keep
track well safely withdraw
might get Enjin refund another wallet ,
allow behavior

Public variables token
Approves calls receiving contract
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead
Creates 21 , 000 , 000 00000000 BOBOv2 ( BB2 ) Tokens

Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Enjin $1M Group Buyer
Moves $1M worth ETH Enjin presale multisig wallet
Enjin multisig wallet : 0xc4740f71323129669424d1Ae06c42AEE99da30e2
Modified version u Cintix Monetha ICOBuyer
Modified @ezra242
Fixes suggested @icoscammer @adevabhaktuni
Please aware users must possess know execute function
Parity Ethereum Mist Wallet withdraw tokens contract
User must specify token address manually withdraw tokens
ERC20 Interface : https : github ethereum EIPs issues 20
minimum amount eth required contract buy
Enjin requires $1000000 @ 306 22 50% bonus
Store amount ETH deposited account
Bounty executing buy
Bounty executing withdrawals
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Emergency kill switch case critical bug found
SHA3 hash kill switch password
Earliest time contract allowed buy crowdsale
time constant past , important Enjin buyer , purchase
Maximum amount user ETH contract accept Reduces risk hard cap related failure
developer address
crowdsale address Settable developer
token address Settable developer
Allows developer set crowdsale addresses
allow developer set sale addresses
allow setting addresses
Set crowdsale token addresses
DEPRECATED Users must execute withdraw specify token address explicitly
contract formerly exploitable malicious dev zeroing former
user balances junk token
Allows developer set token address !
Enjin release token address public crowdsale
theory , developer could shaft everyone setting incorrect token address
Please careful
function set token address ( address token ) {
allow developer set token addresses
require ( msg sender == developer ) ;
Set token addresses
token = ERC20 ( token ) ;
Allows developer anyone password shut everything except withdrawals emergencies
activate kill switch sender developer password correct
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Irreversibly activate kill switch
Send caller bounty activating kill switch
Withdraws ETH deposited tokens purchased given user rewards caller
allow withdrawal requests initiated user !
means every user contract must versed
execute function contract Every user must also supply
correct token address Enjin address known
allow withdrawals contract chance buy
Short circuit save gas user balance
contract failed buy sale , withdraw user's ETH
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Withdraw user's tokens contract purchased
Set token token specified user
work cases user specifies token held contract
also work cases user specifies worthless token held contract
aforementioned case , user zero balance
receive worthless token , affect one else
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
1% fee contract successfully bought tokens
uint256 fee = tokens withdraw 100;
Send fee developer
require ( token transfer ( developer , fee ) ) ;
Send funds Throws failure prevent loss funds
withdraw call earns 1% current withdraw bounty
Update withdraw bounty prior sending prevent recursive call
Send caller bounty withdrawing user's behalf
Allows developer add ETH buy execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Allows developer add ETH withdraw execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Buys tokens crowdsale rewards caller , callable anyone
eth minimum eth contract , buy
Enjin requires $1M minimum 50% bonus
Short circuit save gas contract already bought tokens
Short circuit save gas earliest buy time reached
Short circuit save gas kill switch active
Disallow buying developer set sale address yet
Record contract bought tokens
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Record amount ETH sent contract's current value
Transfer funds ( less bounties ) crowdsale address
buy tokens Throws crowdsale started yet
already completed , preventing loss funds
Send caller bounty buying tokens contract
Default function Called user sends ETH contract
Disallow deposits kill switch active
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Enjin $1M Group Buyer
Moves $1M worth ETH Enjin presale multisig wallet
Enjin multisig wallet : 0xc4740f71323129669424d1Ae06c42AEE99da30e2
Modified version u Cintix Monetha ICOBuyer
ERC20 Interface : https : github ethereum EIPs issues 20
minimum amount eth required contract buy
Enjin requires $1000000 @ 306 22 50% bonus
Store amount ETH deposited account
Bounty executing buy
Bounty executing withdrawals
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Emergency kill switch case critical bug found
SHA3 hash kill switch password
Earliest time contract allowed buy crowdsale
time constant past , important Enjin buyer , purchase
Maximum amount user ETH contract accept Reduces risk hard cap related failure
developer address
crowdsale address Settable developer
token address Settable developer
Allows developer set crowdsale addresses
allow developer set sale addresses
allow setting addresses
Set crowdsale token addresses
Allows developer set token address !
Enjin release token address public crowdsale
theory , developer could shaft everyone setting incorrect token address
Please careful
allow developer set token addresses
Set token addresses
Allows developer anyone password shut everything except withdrawals emergencies
activate kill switch sender developer password correct
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Irreversibly activate kill switch
Send caller bounty activating kill switch
Withdraws ETH deposited tokens purchased given user rewards caller
allow withdrawals contract chance buy
Short circuit save gas user balance
contract failed buy sale , withdraw user's ETH
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Withdraw user's tokens contract purchased
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
1% fee contract successfully bought tokens
Send fee developer
require ( token transfer ( developer , fee ) ) ;
Send funds Throws failure prevent loss funds
withdraw call earns 1% current withdraw bounty
Update withdraw bounty prior sending prevent recursive call
Send caller bounty withdrawing user's behalf
Allows developer add ETH buy execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Allows developer add ETH withdraw execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Buys tokens crowdsale rewards caller , callable anyone
eth minimum eth contract , buy
Enjin requires $1M minimum 50% bonus
Short circuit save gas contract already bought tokens
Short circuit save gas earliest buy time reached
Short circuit save gas kill switch active
Disallow buying developer set sale address yet
Record contract bought tokens
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Record amount ETH sent contract's current value
Transfer funds ( less bounties ) crowdsale address
buy tokens Throws crowdsale started yet
already completed , preventing loss funds
Send caller bounty buying tokens contract
Default function Called user sends ETH contract
Disallow deposits kill switch active
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Copyright ( c ) 2015 2016 Oraclize SRL
Copyright ( c ) 2016 Oraclize LTD
Permission hereby granted , free charge , person obtaining copy
software associated documentation files ( "Software" ) , deal
Software without restriction , including without limitation rights
use , copy , modify , merge , publish , distribute , sublicense , sell
copies Software , permit persons Software
furnished , subject following conditions :
copyright notice permission notice shall included
copies substantial portions Software
SOFTWARE PROVIDED "AS IS" , WITHOUT WARRANTY KIND , EXPRESS
IMPLIED , INCLUDING LIMITED WARRANTIES MERCHANTABILITY ,
FITNESS PARTICULAR PURPOSE NONINFRINGEMENT EVENT SHALL
AUTHORS COPYRIGHT HOLDERS LIABLE CLAIM , DAMAGES
LIABILITY , WHETHER ACTION CONTRACT , TORT OTHERWISE , ARISING ,
CONNECTION SOFTWARE USE DEALINGS
SOFTWARE
external call untrusted contract
check pending withdrawals
ORACLIZE API
please import oraclize API pre0 4 sol solidity 0 4 0
mainnet
ropsten testnet
kovan testnet
rinkeby testnet
ethereum bridge
ether camp ide
browser solidity
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
parse Int
parse Int ( parse Float*10^ b )
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
Step 6 : verify attestation signature , APPKEY1 must sign session Key correct ledger app ( CODEHASH )
role
Step 7 : verify APPKEY1 provenance ( must signed Ledger )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 2 : unique keyhash match sha256 ( context name + query Id )
Step 3 : assume sig1 valid ( verified step 5 ) verify 'result' prefix sha256 ( sig1 )
Step 4 : commitment match verification , sha3 ( delay , nbytes , unonce , session Key Hash ) == commitment storage
verify computed args match ones specified query
unonce , nbytes session Key Hash match
Step 5 : validity verification sig1 ( keyhash args signed session Key )
verify session Pubkey Hash verified already , let's !
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Buffer small
better way ?
NOTE : offset 32 added skip `size` field bytes variables
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Duplicate Solidity's ecrecover , catching CALL return value
memory management Solidity uses memory offset
0x40 store current end memory write past (
writes memory extensions ) , update offset
Solidity reuse memory used needed
context
FIXME : inline assembly can't access return values
NOTE : reuse request memory deal
return code
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
signature format compact form :
{bytes32 r}{bytes32 s}{uint8 v}
Compact means , uint8 padded 32 bytes
loading last 32 bytes exploit fact
'mload' pad zeroes overread
'mload8' , would nicer
Alternative solution :
'byte' working due Solidity parser , lets
use second best option , 'and'
v : = ( mload ( add ( sig , 65 ) ) , 255 )
albeit non transactional signatures specified YP , one would expect
match YP range [27 , 28]
geth uses [0 , 1] clients followed might change , see :
https : github ethereum go ethereum issues 2053
ORACLIZE API
Public vars
0 1 Ether
Regular Vars
Modifiers
Check expected uncalled
Events
Constructor
Receive
Result starts zero , ticket count one
winner yet !
Winner

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Viberate ICO buyer
Avtor : Janez
ERC20 Interface : https : github ethereum EIPs issues 20
Koliko ETH je vlozil vsak racun
Nagrada za izvedbo nakupa
Nagrada za dvig
Podatek ali smo tokene uspesno kupili
Vrednost tokenov v pogodbi
Varnostni kill switch v primeru da se najde kriticen hrosc zelimo pogodbo prekiniti vsem vrniti ETH
SHA3 izvlecek gesla
Kdaj najbolj zgodaj lahko kupimo
Nas interni cap Zato da ne gremo cez hard cap
Naslov razvijalca
Crowdsale naslov lahko nastavi le razvijalec
Naslov tokena lahko nastavi le razvijalec
Razvijalec klicom te funkcije nastavi naslov crowdsale
Samo razvijalec lahko nastavi naslov token
Naslov se lahko nastavi le 1x
Nastavljanje naslova tokena
V skrajni sili lahko razvijalec ali pa kdorkoli posebnim geslom aktivira 'kill switch' Po aktivaciji je mozen le se dvig sredstev
Aktiviraj kill switch samo ce ga aktivira razvijalec , ali pa je geslo pravilno
Nagrado shranimo v zacasno spremenljivko
Nagrado nastavimo na 0
Aktiviramo kill switch
Klicatelju posljemo nagrado
Poslje ETHje ali tokene klicatelju
Ce uporabnik nima denarja koncamo
Ce pogodbi ni uspelo kupiti , potem vrnemo ETH
Pred dvigom shranimo uporabnikov vlozek v zacasno spremenljivko
Uporabnik sedaj nima vec ETH
ETH vrnemo uporabniku
Ce je pogodba uspesno kupila tokene , jih nakazemo uporabniku
Preverimo koliko tokenov ima pogodba
Ce se nimamo tokenov , potem ne dvigujemo
Shranimo stevilo uporabnikovih tokenov v zacasno spremenljivko
Odstejemo uporabnikovo vrednost od vrednosti pogodbe
Odstejemo uporabnikovo vrednost
1% strosek za pogodbo ce smo tokene kupili
Poslji strosek razvijalcu
Posljemo tokene uporabniku
Poslje ETHje uporabniku ali pa tokene nagradi klicatelja funkcije
Dvig dovoljen ce smo kupili tokene ali pa cez eno uro po crowdsalu ( ce nismo ) , ali pa ce je aktiviran kill switch
Ce uporabnik nima denarja koncamo
Ce pogodbi ni uspelo kupiti , potem vrnemo ETH
Pred dvigom shranimo uporabnikov vlozek v zacasno spremenljivko
Uporabnik sedaj nima vec ETH
ETH vrnemo uporabniku
Ce je pogodba uspesno kupila tokene , jih nakazemo uporabniku
Preverimo koliko tokenov ima pogodba
Ce se nimamo tokenov , potem ne dvigujemo
Shranimo stevilo uporabnikovih tokenov v zacasno spremenljivko
Odstejemo uporabnikovo vrednost od vrednosti pogodbe
Odstejemo uporabnikovo vrednost
1% strosek za pogodbo ce smo tokene kupili
Poslji strosek razvijalcu
Posljemo tokene uporabniku
Vsak klic za dvig dobi 1% nagrade za dvig
Zmanjsamo nagrado za dvig
Klicatelju posljemo nagrado
Razvijalec lahko doda ETH v nagrado za vplacilo
Samo razvijalec lahko doda nagrado
Povecaj nagrado
Razvijalec lahko doda nagrado za dvig
Samo razvijalec lahko doda nagrado za dvig
Povecaj nagrado za dvig
Kupi tokene v crowdsalu , nagradi klicatelja funkcijo lahko poklice kdorkoli
Ce smo ze kupili koncamo
Ce cas se ni dosezen , koncamo
Ce je aktiviran 'kill switch' , koncamo
Ce razvijalec se ni dodal naslova , potem ne kupujemo
Zapomnimo si da smo kupili tokene
Nagrado shranemo v zacasno spremenljivko
Nagrade zdaj ni vec
Zapomnimo si koliko ETH smo poslali na crowdsale ( vse razen nagrad )
Poslje celoten znesek ETH ( brez nagrad ) na crowdsale naslov
Klicatelju posljemo nagrado
Ta funkcija se poklice ko kdorkoli poslje ETH na pogodbo
Zavrnemo transakcijo , ce je kill switch aktiviran
Vplacila dovoljena dokler se nismo kupili tokenov
Vplacila dovoljena dokler nismo dosegli nasega capa
Shranimo uporabnikov vlozek

standard uint256 functions
uint128 functions ( h half )
int256 functions
WAD math
RAY math
Amount WEI e amount = 1 means 1 WEI
Convenience aliases
famous algorithm called "exponentiation squaring"
calculates x^n x fixed point n regular unsigned
( log n ) , instead ( n ) naive repeated multiplication
facts works :
n even , x^n = ( x^2 ) ^ ( n 2 )
n odd , x^n = x * x^ ( n 1 ) ,
applying equation even x gives
x^n = x * ( x^2 ) ^ ( ( n 1 ) 2 )
Also , EVM division flooring
floor[ ( n 1 ) 2] = floor[n 2]
standard token precision override customize
Optional token name
AVT PRICES ( ETH AVT )
PURCHASE LIMITS
overrideable easy testing
send ETH multisig

make 9 , 000 OLD FUCKS
( pass 129 )

@ Jordi Baylina
Auditors : Griff Green & psdev
@notice Based http : hudsonjameson ethereummarriage
License : GNU 3
@dev `Owned` base level contract assigns `owner`
later changed
@dev `owner` address call function
modifier
@notice Constructor assigns message sender `owner`
@notice `owner` step assign address role
@param new Owner address new owner
unowned neutral vault , however cannot undone
@notice `new Owner` accept ownership transferred
account contract ability call `accept Ownership`
used accept ownership contract , including contract
functions
general safty function allows owner lot
things unlikely event something goes wrong
dst contract called making like 1 1 multisig
Marriage data variables
Set Owner
Create initial marriage contract
Set marriage status changes
Set IPFS hash image couple
Declare event structure

dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev transfer token specified address
param address transfer
param value amount transferred
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Transfer tokens one address another
param address address want send tokens
param address address want transfer
param value uint256 amout tokens transfered
dev Aprove passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifing amount tokens still avaible spender
dev Function mint tokens
param address recieve minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Monetha Buyer
Buys Monetha tokens crowdsale behalf
Author : u Cintix
ERC20 Interface : https : github ethereum EIPs issues 20
Store amount ETH deposited account
Bounty executing buy
Bounty executing withdrawals
Track whether contract bought tokens yet
Record ETH value tokens currently held contract
Emergency kill switch case critical bug found
SHA3 hash kill switch password
Earliest time contract allowed buy crowdsale
Maximum amount user ETH contract accept Reduces risk hard cap related failure
developer address
crowdsale address Settable developer
token address Settable developer
Allows developer set crowdsale token addresses
allow developer set sale token addresses
allow setting addresses
Set crowdsale token addresses
Allows developer anyone password shut everything except withdrawals emergencies
activate kill switch sender developer password correct
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Irreversibly activate kill switch
Send caller bounty activating kill switch
Withdraws ETH deposited tokens purchased given user rewards caller
allow withdrawals contract chance buy
Short circuit save gas user balance
contract failed buy sale , withdraw user's ETH
Store user's balance prior withdrawal temporary variable
Update user's balance prior sending ETH prevent recursive call
Return user's funds Throws failure prevent loss funds
Withdraw user's tokens contract purchased
Retrieve current token balance contract
Disallow token withdrawals tokens withdraw
Store user's token balance temporary variable
Update value tokens currently held contract
Update user's balance prior sending prevent recursive call
1% fee contract successfully bought tokens
Send fee developer
Send funds Throws failure prevent loss funds
withdraw call earns 1% current withdraw bounty
Update withdraw bounty prior sending prevent recursive call
Send caller bounty withdrawing user's behalf
Allows developer add ETH buy execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Allows developer add ETH withdraw execution bounty
allow developer contribute buy execution bounty
Update bounty include received amount
Buys tokens crowdsale rewards caller , callable anyone
Short circuit save gas contract already bought tokens
Short circuit save gas earliest buy time reached
Short circuit save gas kill switch active
Disallow buying developer set sale address yet
Record contract bought tokens
Store claimed bounty temporary variable
Update bounty prior sending prevent recursive call
Record amount ETH sent contract's current value
Transfer funds ( less bounties ) crowdsale address
buy tokens Throws crowdsale started yet
already completed , preventing loss funds
Send caller bounty buying tokens contract
Default function Called user sends ETH contract
Disallow deposits kill switch active
allow deposits contract already purchased tokens
allow deposits exceed contract's ETH cap
Update records deposited ETH include received amount

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

optional
optional
Optional
Optional
function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
Initial
total supply
Set name
Amount decimals
Symbol

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

constructor

Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filters applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Copyright ( c ) 2015 2016 Oraclize SRL
Copyright ( c ) 2016 Oraclize LTD
Permission hereby granted , free charge , person obtaining copy
software associated documentation files ( "Software" ) , deal
Software without restriction , including without limitation rights
use , copy , modify , merge , publish , distribute , sublicense , sell
copies Software , permit persons Software
furnished , subject following conditions :
copyright notice permission notice shall included
copies substantial portions Software
SOFTWARE PROVIDED "AS IS" , WITHOUT WARRANTY KIND , EXPRESS
IMPLIED , INCLUDING LIMITED WARRANTIES MERCHANTABILITY ,
FITNESS PARTICULAR PURPOSE NONINFRINGEMENT EVENT SHALL
AUTHORS COPYRIGHT HOLDERS LIABLE CLAIM , DAMAGES
LIABILITY , WHETHER ACTION CONTRACT , TORT OTHERWISE , ARISING ,
CONNECTION SOFTWARE USE DEALINGS
SOFTWARE
title String & slice utility library Solidity contracts
Nick Johnson [email protected]
dev Functionality library largely implemented using
abstraction called 'slice' slice represents part string
anything entire string single character , even
characters ( 0 length slice ) Since slice specify
offset length , copying manipulating slices lot less
expensive copying manipulating strings reference
reduce gas costs , functions slice need return
slice modify original one instead allocating new one;
instance , `s split ( " " ) ` return text first ' ' ,
modifying contain remainder string ' '
situations want modify original slice ,
make copy first ` copy ( ) ` , example :
`s copy ( ) split ( " " ) ` Try avoid using idiom loops; since
Solidity memory management , result allocating many
short lived slices later discarded
Functions return two slices come two versions : non allocating
version takes second slice argument , modifying
place , allocating version allocates returns second
slice; see `next Rune` example
Functions copy string data return strings rather
slices; cast back slices processing
required
convenience , functions provided non modifying
variants create new slice return both; instance ,
`s split New ( ' ' ) ` leaves unmodified , returns two values
corresponding left right parts string
dev Returns slice containing entire string
param self string make slice
return newly allocated slice containing entire string
dev Returns length null terminated bytes32 string
param self value find length
return length string , 0 32
dev Returns slice containing entire bytes32 , interpreted
null termintaed utf 8 string
param self bytes32 value convert slice
return new slice containing value input argument
first null
dev Returns new slice containing data current slice
param self slice copy
return new slice containing data `self`
dev Copies slice new string
param self slice copy
return newly allocated string containing slice's text
dev Returns length runes slice Note operation
takes time proportional length slice; avoid using
loops , call `slice empty ( ) ` need know whether
slice empty
param self slice operate
return length slice runes
dev Returns true slice empty ( length 0 )
param self slice operate
return True slice empty , False otherwise
dev Returns positive number `other` comes lexicographically
`self` , negative number comes , zero
contents two slices equal Comparison done per rune ,
unicode codepoints
param self first slice compare
param second slice compare
return result comparison
dev Returns true two slices contain text
param self first slice compare
param self second slice compare
return True slices equal , false otherwise
dev Extracts first rune slice `rune` , advancing
slice point next rune returning `self`
param self slice operate
param rune slice contain first rune
return `rune`
dev Returns first rune slice , advancing slice point
next rune
param self slice operate
return slice containing first rune `self`
dev Returns number first codepoint slice
param self slice operate
return number first codepoint slice
dev Returns keccak 256 hash slice
param self slice hash
return hash slice
dev Returns true `self` starts `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` starts `needle` , `needle` removed
beginning `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Returns true slice ends `needle`
param self slice operate
param needle slice search
return True slice starts provided text , false otherwise
dev `self` ends `needle` , `needle` removed
end `self` Otherwise , `self` unmodified
param self slice operate
param needle slice search
return `self`
dev Modifies `self` contain everything first occurrence
`needle` end slice `self` set empty slice
`needle` found
param self slice search modify
param needle text search
return `self`
dev Modifies `self` contain part string start
`self` end first occurrence `needle` `needle`
found , `self` set empty slice
param self slice search modify
param needle text search
return `self`
dev Splits slice , setting `self` everything first
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything first
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` first occurrence `delim`
dev Splits slice , setting `self` everything last
occurrence `needle` , `token` everything
`needle` occur `self` , `self` set empty slice ,
`token` set entirety `self`
param self slice split
param needle text search `self`
param token output parameter first token written
return `token`
dev Splits slice , setting `self` everything last
occurrence `needle` , returning everything
`needle` occur `self` , `self` set empty slice ,
entirety `self` returned
param self slice split
param needle text search `self`
return part `self` last occurrence `delim`
dev Counts number nonoverlapping occurrences `needle` `self`
param self slice search
param needle text search `self`
return number occurrences `needle` found `self`
dev Returns True `self` contains `needle`
param self slice search
param needle text search `self`
return True `needle` found `self` , false otherwise
dev Returns newly allocated string containing concatenation
`self` `other`
param self first slice concatenate
param second slice concatenate
return concatenation two strings
dev Joins array slices , using `self` delimiter , returning
newly allocated string
param self delimiter use
param parts list slices join
return newly allocated string containing slices `parts` ,
joined `self`
checks player profit , bet size player number within range
checks game currently active
checks payouts currently active
checks Oraclize address calling
checks owner address calling
checks treasury address calling
game vars
player vars
events
log bets + output web3 precise 'payout win' field UI
output web3 UI bet result
Status : 0=lose , 1=win , 2=win + failed send , 3=refund , 4=refund + failed send
log manual refunds
log owner transfers
init
use TLSNotary oraclize call
init 990 = 99% ( 1% house Edge )
init 10 , 000 = 1%
init min bet ( 0 1 ether )
init gas oraclize
public function
player submit bet
game active & bet valid query oraclize set player vars
safely update contract balance account cost call oraclize
total number bets
total wagered
assign partially encrypted query oraclize
api Key encrypted
integer query plain text
map bet id oraclize query
map player lucky number oraclize query
map value wager oraclize query
map player address oraclize query
safely map player profit oraclize query
safely increase max Pending Payouts liability calc pending payouts assumption win
check contract payout win
provides accurate numbers web3 allows manual refunds case oraclize callback
semi public function oraclize call
TLSNotary oraclize call
player address mapped query id exist
keep oraclize honest retrieving serial Number random org result
map result player
get player Address query id
delete player Address query id
map player Profit query id
set player Profit query id 0
safely reduce max Pending Payouts liability
map player Bet Value query id
set player Bet Value query id 0
refund
result 0 result empty proof refund original bet value
refund fails save refund value player Pending Withdrawals
send refund external call untrusted contract
send fails map refund value player Pending Withdrawals[address]
withdrawal later via player Withdraw Pending Transactions
send failed let player withdraw via player Withdraw Pending Transactions
pay winner
update contract balance calculate new max bet
send reward
send reward fails save value player Pending Withdrawals
safely reduce contract balance player profit
update total wei
safely calculate payout via profit plus original wager
update maximum profit
send win external call untrusted contract
send fails map reward value player Pending Withdrawals[address]
withdrawal later via player Withdraw Pending Transactions
send failed let player withdraw via player Withdraw Pending Transactions
win
send 1 wei losing bet
update contract balance calculate new max bet
safe adjust contract Balance
set Max Profit
send 1 wei losing bet
update maximum profit
send 1 wei external call untrusted contract
send failed let player withdraw via player Withdraw Pending Transactions
public function
case failed refund win send
external call untrusted contract
send failed revert player Pending Withdrawals[msg sender] = 0;
player try withdraw later
check pending withdrawals
internal function
sets max profit
owner treasury address functions
safely update contract balance
update maximum profit
set gas oraclize query
owner adjust contract balance variable ( used max profit calc )
owner address set house Edge
owner address set max Profit Percent House
restrict bet maximum profit 10% contract Balance
owner address set min Bet
owner address transfer ether
safely update contract balance sending funds
update max profit
owner address manual refund
used bet placed + oraclize failed callback
filter Log Bet address player Bet Id :
Log Bet ( player Bet Id[rng Id] , player Address[rng Id] , safe Add ( player Bet Value[rng Id] , player Profit[rng Id] ) , player Profit[rng Id] , player Bet Value[rng Id] , player Number[rng Id] ) ;
check following logs exist player Bet Id player Address[rng Id] refunding :
Log Result Log Refund
Log Result exists player use withdraw pattern player Withdraw Pending Transactions
safely reduce pending Payouts player Profit[rng Id]
send refund
log refunds
owner address set emergency pause 1
owner address set emergency pause 2
owner address set treasury address
owner address set owner address
owner address suicide emergency
ORACLIZE API
please import oraclize API pre0 4 sol solidity 0 4 0
mainnet
ropsten testnet
kovan testnet
rinkeby testnet
ethereum bridge
ether camp ide
browser solidity
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
unexpectedly high price
parse Int
parse Int ( parse Float*10^ b )
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
get correct cbor output length
+3 accounts paired identifier types
there's bug larger strings , may culprit
Step 6 : verify attestation signature , APPKEY1 must sign session Key correct ledger app ( CODEHASH )
role
Step 7 : verify APPKEY1 provenance ( must signed Ledger )
Step 1 : prefix match 'LP\x01' ( Ledger Proof version 1 )
Step 2 : unique keyhash match sha256 ( context name + query Id )
Step 3 : assume sig1 valid ( verified step 5 ) verify 'result' prefix sha256 ( sig1 )
Step 4 : commitment match verification , sha3 ( delay , nbytes , unonce , session Key Hash ) == commitment storage
verify computed args match ones specified query
unonce , nbytes session Key Hash match
Step 5 : validity verification sig1 ( keyhash args signed session Key )
verify session Pubkey Hash verified already , let's !
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Buffer small
better way ?
NOTE : offset 32 added skip `size` field bytes variables
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
Duplicate Solidity's ecrecover , catching CALL return value
memory management Solidity uses memory offset
0x40 store current end memory write past (
writes memory extensions ) , update offset
Solidity reuse memory used needed
context
FIXME : inline assembly can't access return values
NOTE : reuse request memory deal
return code
following function written Alex Beregszaszi ( @axic ) , use terms MIT license
signature format compact form :
{bytes32 r}{bytes32 s}{uint8 v}
Compact means , uint8 padded 32 bytes
loading last 32 bytes exploit fact
'mload' pad zeroes overread
'mload8' , would nicer
Alternative solution :
'byte' working due Solidity parser , lets
use second best option , 'and'
v : = ( mload ( add ( sig , 65 ) ) , 255 )
albeit non transactional signatures specified YP , one would expect
match YP range [27 , 28]
geth uses [0 , 1] clients followed might change , see :
https : github ethereum go ethereum issues 2053
ORACLIZE API
Copy word length chunks possible
Copy remaining bytes
Allocate space `self` memory , copy , point ret
Starting ptr 31 means LSB byte care
Mask irrelevant bytes check
Load first byte rune LSBs b
Check truncated codepoints
Load rune MSBs b
Check truncated codepoints
Invalid UTF 8 sequence
Returns memory address first byte first occurrence
`needle` `self` , first byte `self` found
Optimized assembly 68 gas per byte short strings
long needles , use hashing
Returns memory address first byte last occurrence
`needle` `self` , address `self` found
Optimized assembly 69 gas per byte short strings
long needles , use hashing
found
found
init dicontinued contract data
init dicontinued contract data
init dicontinued contract data
api random org json rpc 1 invoke ) result random[\"serial Number\" , \"data\"]' , '\\n{\"jsonrpc\" : \"2 0\" , \"method\" : \"generate Signed Integers\" , \"params\" : {\"n\" : 1 , \"min\" : 1 , \"max\" : 100 , \"replacement\" : true , \"base\" : 10 , \"api Key\" : ${[decrypt] BCH6h HWdskd8vb1Iy Juf Vawsv BSs XN34RTD3rb3g Fz2 c Fp Y1s5z Oz FXTl+YOwt9vhf Jew Hxlp79y VBCQ r FOVy4w XS4Gm GHy7DAZJt5YZmnq1P fsn ABq Zqvbvt KIn Au ID+DWy F+HVMtx+iurp Z3Ghhz I7H+8=}${[identity] \"}\"} , \"id\" : \"Smart Contract Casino\"${[identity] \"}\"}']" , gas Oraclize ) ;

Interface defining crowdsale pricing
Interface declaration
Self check references correctly set
Checks pricing strategy matches crowdsale parameters
somebody tries buy tokens X eth , calculate many tokens get
param value value transaction send wei
param tokens Sold much tokens sold far
param wei Raised much money raised far
param msg Sender investor transaction
param decimals many decimal units token
return Amount tokens investor receives
ERC20 interface
see https : github ethereum EIPs issues 20
Math operations safety checks
Standard ERC20 token Short Hand Attack approve ( ) race condition mitigation
Based code First Blood :
https : github Firstbloodio token blob master smart contract First Blood Token sol
Token supply got increased new owner received tokens
Actual balances token holders
approve ( ) allowances
Interface declaration
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
crowdsale co referral contract WWAM ICO
Holding number wei invested referral contract

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Interface defining crowdsale pricing
Interface declaration
Self check references correctly set
Checks pricing strategy matches crowdsale parameters
somebody tries buy tokens X eth , calculate many tokens get
param value value transaction send wei
param tokens Sold much tokens sold far
param wei Raised much money raised far
param msg Sender investor transaction
param decimals many decimal units token
return Amount tokens investor receives
ERC20 interface
see https : github ethereum EIPs issues 20
Math operations safety checks
Standard ERC20 token Short Hand Attack approve ( ) race condition mitigation
Based code First Blood :
https : github Firstbloodio token blob master smart contract First Blood Token sol
Token supply got increased new owner received tokens
Actual balances token holders
approve ( ) allowances
Interface declaration
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
crowdsale co referral contract WWAM ICO
Holding number wei invested referral contract

Interface defining crowdsale pricing
Interface declaration
Self check references correctly set
Checks pricing strategy matches crowdsale parameters
somebody tries buy tokens X eth , calculate many tokens get
param value value transaction send wei
param tokens Sold much tokens sold far
param wei Raised much money raised far
param msg Sender investor transaction
param decimals many decimal units token
return Amount tokens investor receives
ERC20 interface
see https : github ethereum EIPs issues 20
Math operations safety checks
Standard ERC20 token Short Hand Attack approve ( ) race condition mitigation
Based code First Blood :
https : github Firstbloodio token blob master smart contract First Blood Token sol
Token supply got increased new owner received tokens
Actual balances token holders
approve ( ) allowances
Interface declaration
github ethereum EIPs issues 20
github Firstbloodio token blob master smart contract First Blood Token sol
change approve amount first reduce addresses`
allowance zero calling `approve ( spender , 0 ) `
already 0 mitigate race condition described :
https : github ethereum EIPs issues 20 issuecomment 263524729
coinschedule referral contract WWAM ICO
Holding number wei invested referral contract

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public functions
Internal functions
Web3 call functions
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George [email protected]
@dev Contract constructor sets initial owners , required number confirmations daily withdraw limit
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount

Public functions
Internal functions
Web3 call functions
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George [email protected]
@dev Contract constructor sets initial owners , required number confirmations daily withdraw limit
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Wallet contract operates "right" branch
Owner wallet
set true currently "right" branch
blockchain , e branch wallet operating
Instantiate contract
@param owner owner contract
@is Right Branch whether currently "right" branch
accept money "right" branch
Execute transaction using money wallet
@param transaction destination
@param value transaction value
@param data transaction data
Execute transaction using money wallet
@param transaction destination
@param value transaction value
@param data transaction data
Simple smart contract allows anyone tell currently
"right" branch blockchain
set true currently "right" branch
blockchain

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Originally https : github Consen Sys Multi Sig Wallet
Public functions
Internal functions
Web3 call functions
github Consen Sys Multi Sig Wallet
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George [email protected]
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

Public functions
Internal functions
Web3 call functions
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs

implements standard functions NOTHING else
token like would want deploy something like Mist , see Human Standard Token sol
deploy , anything useful
Implements ERC 20 Token standard : https : github ethereum EIPs issues 20
Token Contract implements standard token functionality ( https : github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
words intended deployment something like Token Factory Mist wallet , used humans
Imagine coins , currencies , shares , voting weight , etc
Machine based , rapid creation many tokens would necessarily need extra features minted manners
1 ) Initial Finite Supply ( upon creation one specifies much minted )
2 ) absence token registry : Optional Decimal , Symbol & Name
3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
github ethereum EIPs issues 20
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
github ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
ether sent address , send back
fancy name : eg Simon Bucks
many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
identifier : eg SBX
human 0 1 standard arbitrary versioning scheme
Give creator initial tokens
Update total supply
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

last compiled soljson v0 3 5 6610add js
internals
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && value 0 ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && value 0 ) {
Reality Keys :
percentage 1 ether
send X Ether , get X Yes tokens X tokens
yes

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

King Ether Throne Contracts
Copyright ( c ) 2016 Kieran Elby Released MIT License
Version 1 0 0 , 31 July 2016
See also http : www kingoftheether
https : github kieranelby King Ether Throne
file contains number contracts ,
three normally created :
Kingdom = maintains throne kingdom
World = runs world , collection kingdoms
Kingdom Factory = used internally World contract
"Mixin" contracts ( Throne Rules Mixin , Reentry Protector Mixin ,
Careful Sender Mixin , Funds Holder Mixin , Money Rounder Mixin ,
Nameable Mixin ) contain functions data structures used
three main contracts
Exposed Internals Testing contract used automated tests
@title Mixin help avoid recursive call attacks
true inside external function
Mark contract entered external function
Throws exception called twice external Leave ( )
work , Contracts MUST :
call external Enter ( ) start external function
call external Leave ( ) end external function
never use return statements enter leave
never call external function another function
WARN : serious risk contract getting stuck used wrongly
Mark contract left external function
call external Enter ( )
@title Mixin help send ether untrusted addresses
Seems reasonable amount well written fallback function
Send ` value Wei` ether ` Address` , including
` extra Gas Included` gas usual 2300 gas stipend
send call
needs care way tell Address
externally owned another contract sending ether
contract address invoke fallback function;
three implications :
1 ) Danger recursive attack
destination contract's fallback function ( another
contract calls ) may call back contract ( including
fallback function external functions inherited ,
contracts stack ) , leading unexpected behaviour
Mitigations :
protect external functions entry
( see Reentry Protector Mixin ) ;
program defensively ( e g debit balance send )
2 ) Destination fallback function fail
destination contract's fallback function fails , ether
sent may locked sending contract
Unlike errors , cause contract throw
Mitigations :
check return value function ( see )
3 ) Gas usage
destination fallback function consume gas supplied
transaction ( fixed set transaction
starter , though clients good job estimating
problem lottery type contracts one
expensive call receiving contract could 'poison' lottery
contract preventing invoked another person
cannot supply enough gas
Mitigations :
choose sensible value extra Gas Included ( default
2300 gas supplied destination function ) ;
call fails consider whether throw ring fence
funds later withdrawal
Returns :
True send call made throw
error case , longer value Wei
ether Note cannot get return value fallback
function called ( )
False send made destination fallback function
threw error ( ran gas ) hapens , still
value Wei ether destination's actions undone
function normally throw error unless :
enough gas make send call
max call stack depth reached
insufficient ether
@title Mixin help track owns ether allow withdrawals
Record much wei owned address
Obviously , entries MUST backed actual ether
owned contract cannot enforce mixin
@notice Amount ether held ` address`
@notice Send caller ( `msg sender` ) ether
@notice Send ` value Wei` ether owned caller
( `msg sender` ) ` Address` , including ` extra Gas` gas
beyond normal stipend
@dev internal version withdraw Funds ( )
@dev internal version withdraw Funds Advanced ( ) , also used
withdraw Funds RP ( )
@title Mixin help make nicer looking ether amounts
@notice Make ` raw Value Wei` nicer , rounder number
@return value :
larger ` raw Value Wei`
smaller ` raw Value Wei` * 0 999
three significant figures UNLESS
number small large monetary terms
( define 1 finney 10000 ether ) ,
case precision lost
@notice Convert ` value Wei` whole number finney
@return smallest whole number finney equal
greater ` value Wei` converted wei
WARN : May incorrect ` value Wei` 2**254
@title Mixin help allow users name things
String manipulation expensive EVM; keep things short
@notice Check ` name` reasonable choice name
@return True ` name ` meets criteria
, false otherwise :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
least one non punctuation character
Note deliberately exclude characters may cause
security problems websites databases escaping
performed correctly , " '
Apologies lack non English language support
Z
z
space
Extract name bytes ` data` ( presumably `msg data` ) ,
throw exception data expected format
want make easy people name things , even
they're comfortable calling functions contracts
allow names sent fallback function encoded
message data
Unfortunately , way Ethereum Function ABI works means
must careful avoid clashes message data
represents names message data represents call
external function otherwise :
) names usable;
b ) small possibility phishing attack users
tricked using certain names cause external
function call e g data sent contract
keccak256 ( "withdraw Funds ( ) " ) withdrawal occur
require prefix "NAME : " start name ( encoded
ASCII ) sent via fallback function prefix
clash external function signature hashes
e g web3 Ascii ( 'NAME : ' + 'Joe Bloggs' )
WARN : check name "reasonableness";
use validate Name Internal ( )
check prefix present
copy data prefix
Turn short name "fuzzy hash" property
extremely similar names fuzzy hash
useful :
stop people choosing names differ case
punctuation would lead confusion
faciliate searching name without needing exact match
example , names fuzzy hash :
"Banana"
"BANANA"
"Ba na na"
" banana "
"Banana long end ignored"
hand , "Banana1" "A Banana" different
WARN : likely work poorly names meet
validate Name Internal ( ) test
Z
fold z Z
ignore others
@title Mixin help define rules throne
See World create Kingdom ( ) documentation
@title Maintains throne kingdom
e g "King Ether"
World contract used create kingdom , 0x0 none
rules govern kingdom see Throne Rules Mixin
Someone ruled ( ruling ) kingdom
send compensation
name
became ruler
claim price paid ( excluding payment )
compensation sent held far
first ruler number 1; zero th entry dummy entry
top Wizard earns half commission
normally owner World contract
sub Wizard earns half commission
normally creator Kingdom
top Wizard sub Wizard address
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
WARN validate arguments; MUST either call
Kingdom Factory validate Proposed Throne Rules ( ) create
Kingdom via Kingdom Factory World's create Kingdom ( )
See World create Kingdom ( ) parameter documentation
number monarchs starting 1; sometimes useful
use zero = invalid , put dummy entry number 0
zero th entry invalid
False either monarchs , latest monarch
reigned long struck curse
possible , think miners reject blocks
timestamps go backwards ? drift possible
needs handling unsigned overflow audit checks
@notice much must pay claim throne , wei
danger overflow claim price never gets high
@notice much must pay claim throne , finney
@notice Check name used monarch name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
Get details latest monarch ( even dead )
expose externally returning structs well
supported ABI ( strange monarchs Number array works
fine though ) Note reference returned writable
used update details latest monarch
WARN : check number Monarchs ( ) 0 first
@notice Claim throne sending funds contract
future compensation earned sent sender's
address ( `msg sender` )
Sending contract recommended unless know
( tested )
message data supplied , throne claimed
name "Anonymous" supply name , send data encoded
using web3 Ascii ( 'NAME : ' + 'your chosen valid name' )
Sender must include payment equal current Claim Price Wei ( )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event`
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Claim throne given ` monarch Name`
future compensation earned sent caller's
address ( `msg sender` )
Caller must include payment equal current Claim Price Wei ( )
Calling contract recommended unless know
( tested )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Used either top Wizard sub Wizard transfer
rights future commissions ` replacement` wizard
WARN : original wizard retains ownership past
commission held `funds` mapping ,
still withdraw
Produces event Wizard Replaced Event
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
dead men get compensation
case teeny excess , use official price
since determine new claim price , paid Wei
Careful top Wizard sub Wizard address ,
case must replace
Allow commission funds build contract wizards
withdraw ( carefully ring fenced )
give sub Wizard "odd" single wei
Send compensation latest monarch ( hold funds
cannot fault current caller )
record compensated
WARN : latest monarch contract whose fallback
function needs 25300 gas
receive compensation automatically
happen latest monarch contract
whose fallback function failed ran gas ( despite
us including fair amount gas )
throw since want throne get
'stuck' ( new usurpers fault ) instead save
funds could send claimed later
monarch contract would need designed
call withdraw Funds Advanced ( ) function mind
@title Used World contract create Kingdom instances
@dev Mostly exists top Wizard potentially replace
contract modify Kingdom contract rule validation
logic used *future* Kingdoms created World
implement rentry protection send call
charge fee bypass World
listed official World page course
contract never balance
See World create Kingdom ( ) parameter documentation
suppose danger massive deflation inflation could
change real world sanity checks , case
deploy new factory update world
@notice Create new Kingdom Normally called World contract
WARN : validate kingdom Name world arguments
consume 1 , 800 , 000 gas ( ! )
throw error :
rules invalid ( see validate Proposed Throne Rules )
wizard addresses "obviously" wrong
gas quite likely ( perhaps future consider
using solidity libraries reduce Kingdom size ? )
See World create Kingdom ( ) parameter documentation
contract never balance
NB : top Wizard sub Wizard
@title Runs world , collection Kingdoms
top Wizard runs world charge creation
kingdoms become top Wizard kingdom created
much one must pay create new kingdom ( wei )
changed top Wizard
first kingdom number 1; zero th entry dummy
safety , cap high price get
changed top Wizard , though affect
kingdoms created
Helper contract creating Kingdom instances
upgraded top Wizard ( affect existing ones )
Avoids duplicate kingdom names allows searching name
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
Create world kingdoms yet
Costs 1 9M gas deploy
number kingdoms starting 1 since sometimes
useful use zero = invalid Create dummy zero th entry
@return index kingdoms Number found , zero
@notice Check name used kingdom name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
WARN : check name already use;
use `find Kingdom Called ( string ) ` afterwards
Check rules would allowed new custom Kingdom
Typically used calling `create Kingdom ( ) `
much one must pay create new kingdom ( finney )
changed top Wizard
Reject funds sent contract wizards cannot interact
via API able withdraw commission
@notice Create new kingdom using custom rules
@param kingdom Name \
e g "King Ether Throne"
@param starting Claim Price Wei \
much cost first monarch claim throne
( also price death monarch )
@param claim Price Adjust Percent \
Percentage increase claim e g claim price
200 ETH , ` claim Price Adjust Percent` 50 , next
claim price 200 ETH + ( 50% 200 ETH ) = 300 ETH
@param curse Incubation Duration Seconds \
maximum length time monarch rule
curse strikes removed without compensation
@param commission Per Thousand \
much payment given wizards share ,
expressed parts per thousand e g 25 means 25 1000 ,
Caller must include payment equal kingdom Creation Fee Wei
caller become 'sub wizard' earn half
commission charged Kingdom Note however
need call withdraw Funds ( ) Kingdom contract
get commission send automatically
consume 1 , 900 , 000 gas ( ! )
throw error :
name invalid ( see `validate Proposed Kingdom Name ( string ) ` )
name already use ( see `find Kingdom Called ( string ) ` )
rules invalid ( see `validate Proposed Kingdom Rules ( ) ` )
payment low high
insufficient gas ( quite likely ! )
Produces event Kingdom Created Event
@notice Used top Wizard transfer rights future
fees future kingdom wizardships ` replacement` wizard
WARN : original wizard retains ownership past fees
held `funds` mapping , still
withdraw also remain top Wizard existing Kingdoms
Produces event Wizard Replaced Event
@notice Used top Wizard vary fee creating kingdoms
@notice Used top Wizard vary cap claim price
@notice Used top Wizard vary factory contract
used create future Kingdoms
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
perform rule validation
existing kingdom called ` kingdom Name` , create
record mapping name kingdom ` new Kingdom Number`
Throws error existing kingdom (
fuzzily similar see compute Name Fuzzy Hash ) name exists
@title Used testnet allow automated testing internals

forked chain send ETH eth Address
forked chain send ETC etc Address less fee
Reject deposits contract
IOn Fork oracle tr

King Ether Throne Contracts
Copyright ( c ) 2016 Kieran Elby Released MIT License
Version 0 9 9 2 , July 2016
See also http : www kingoftheether
https : github kieranelby King Ether Throne
file contains number contracts ,
three normally created :
Kingdom = maintains throne kingdom
World = runs world , collection kingdoms
Kingdom Factory = used internally World contract
"Mixin" contracts ( Throne Rules Mixin , Reentry Protector Mixin ,
Careful Sender Mixin , Funds Holder Mixin , Money Rounder Mixin ,
Nameable Mixin ) contain functions data structures used
three main contracts
Exposed Internals Testing contract used automated tests
@title Mixin help avoid recursive call attacks
true inside external function
Mark contract entered external function
Throws exception called twice external Leave ( )
work , Contracts MUST :
call external Enter ( ) start external function
call external Leave ( ) end external function
never use return statements enter leave
never call external function another function
WARN : serious risk contract getting stuck used wrongly
Mark contract left external function
call external Enter ( )
@title Mixin help send ether untrusted addresses
Seems reasonable amount well written fallback function
Send ` value Wei` ether ` Address` , including
` extra Gas Included` gas usual 2300 gas stipend
send call
needs care way tell Address
externally owned another contract sending ether
contract address invoke fallback function;
three implications :
1 ) Danger recursive attack
destination contract's fallback function ( another
contract calls ) may call back contract ( including
fallback function external functions inherited ,
contracts stack ) , leading unexpected behaviour
Mitigations :
protect external functions entry
( see Reentry Protector Mixin ) ;
program defensively ( e g debit balance send )
2 ) Destination fallback function fail
destination contract's fallback function fails , ether
sent may locked sending contract
Unlike errors , cause contract throw
Mitigations :
check return value function ( see )
3 ) Gas usage
destination fallback function consume gas supplied
transaction ( fixed set transaction
starter , though clients good job estimating
problem lottery type contracts one
expensive call receiving contract could 'poison' lottery
contract preventing invoked another person
cannot supply enough gas
Mitigations :
choose sensible value extra Gas Included ( default
2300 gas supplied destination function ) ;
call fails consider whether throw ring fence
funds later withdrawal
Returns :
True send call made throw
error case , longer value Wei
ether Note cannot get return value fallback
function called ( )
False send made destination fallback function
threw error ( ran gas ) hapens , still
value Wei ether destination's actions undone
function normally throw error unless :
enough gas make send call
max call stack depth reached
insufficient ether
@title Mixin help track owns ether allow withdrawals
Record much wei owned address
Obviously , entries MUST backed actual ether
owned contract cannot enforce mixin
@notice Amount ether held ` address`
@notice Send caller ( `msg sender` ) ether
@notice Send ` value Wei` ether owned caller
( `msg sender` ) ` Address` , including ` extra Gas` gas
beyond normal stipend
@dev internal version withdraw Funds ( )
@dev internal version withdraw Funds Advanced ( ) , also used
withdraw Funds RP ( )
@title Mixin help make nicer looking ether amounts
@notice Make ` raw Value Wei` nicer , rounder number
@return value :
larger ` raw Value Wei`
smaller ` raw Value Wei` * 0 999
three significant figures UNLESS
number small large monetary terms
( define 1 finney 10000 ether ) ,
case precision lost
@notice Convert ` value Wei` whole number finney
@return smallest whole number finney equal
greater ` value Wei` converted wei
WARN : May incorrect ` value Wei` 2**254
@title Mixin help allow users name things
String manipulation expensive EVM; keep things short
@notice Check ` name` reasonable choice name
@return True ` name ` meets criteria
, false otherwise :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
least one non punctuation character
Note deliberately exclude characters may cause
security problems websites databases escaping
performed correctly , " '
Apologies lack non English language support
Z
z
space
Extract name bytes ` data` ( presumably `msg data` ) ,
throw exception data expected format
want make easy people name things , even
they're comfortable calling functions contracts
allow names sent fallback function encoded
message data
Unfortunately , way Ethereum Function ABI works means
must careful avoid clashes message data
represents names message data represents call
external function otherwise :
) names usable;
b ) small possibility phishing attack users
tricked using certain names cause external
function call e g data sent contract
keccak256 ( "withdraw Funds ( ) " ) withdrawal occur
require prefix "NAME : " start name ( encoded
ASCII ) sent via fallback function prefix
clash external function signature hashes
e g web3 Ascii ( 'NAME : ' + 'Joe Bloggs' )
WARN : check name "reasonableness";
use validate Name Internal ( )
check prefix present
copy data prefix
Turn short name "fuzzy hash" property
extremely similar names fuzzy hash
useful :
stop people choosing names differ case
punctuation would lead confusion
faciliate searching name without needing exact match
example , names fuzzy hash :
"Banana"
"BANANA"
"Ba na na"
" banana "
"Banana long end ignored"
hand , "Banana1" "A Banana" different
WARN : likely work poorly names meet
validate Name Internal ( ) test
Z
fold z Z
ignore others
@title Mixin help define rules throne
See World create Kingdom ( ) documentation
@title Maintains throne kingdom
e g "King Ether"
World contract used create kingdom , 0x0 none
rules govern kingdom see Throne Rules Mixin
Someone ruled ( ruling ) kingdom
send compensation
name
became ruler
claim price paid ( excluding payment )
compensation sent held far
first ruler number 1; zero th entry dummy entry
top Wizard earns half commission
normally owner World contract
sub Wizard earns half commission
normally creator Kingdom
top Wizard sub Wizard address
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
WARN validate arguments; MUST either call
Kingdom Factory validate Proposed Throne Rules ( ) create
Kingdom via Kingdom Factory World's create Kingdom ( )
See World create Kingdom ( ) parameter documentation
number monarchs starting 1; sometimes useful
use zero = invalid , put dummy entry number 0
zero th entry invalid
False either monarchs , latest monarch
reigned long struck curse
possible , think miners reject blocks
timestamps go backwards ? drift possible
needs handling unsigned overflow audit checks
@notice much must pay claim throne , wei
danger overflow claim price never gets high
@notice much must pay claim throne , finney
@notice Check name used monarch name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
Get details latest monarch ( even dead )
expose externally returning structs well
supported ABI ( strange monarchs Number array works
fine though ) Note reference returned writable
used update details latest monarch
WARN : check number Monarchs ( ) 0 first
@notice Claim throne sending funds contract
future compensation earned sent sender's
address ( `msg sender` )
Sending contract recommended unless know
( tested )
message data supplied , throne claimed
name "Anonymous" supply name , send data encoded
using web3 Ascii ( 'NAME : ' + 'your chosen valid name' )
Sender must include payment equal current Claim Price Wei ( )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event`
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Claim throne given ` monarch Name`
future compensation earned sent caller's
address ( `msg sender` )
Caller must include payment equal current Claim Price Wei ( )
Calling contract recommended unless know
( tested )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Used either top Wizard sub Wizard transfer
rights future commissions ` replacement` wizard
WARN : original wizard retains ownership past
commission held `funds` mapping ,
still withdraw
Produces event Wizard Replaced Event
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
dead men get compensation
case teeny excess , use official price
since determine new claim price , paid Wei
Careful top Wizard sub Wizard address ,
case must replace
Allow commission funds build contract wizards
withdraw ( carefully ring fenced )
give sub Wizard "odd" single wei
Send compensation latest monarch ( hold funds
cannot fault current caller )
record compensated
WARN : latest monarch contract whose fallback
function needs 25300 gas
receive compensation automatically
happen latest monarch contract
whose fallback function failed ran gas ( despite
us including fair amount gas )
throw since want throne get
'stuck' ( new usurpers fault ) instead save
funds could send claimed later
monarch contract would need designed
call withdraw Funds Advanced ( ) function mind
@title Used World contract create Kingdom instances
@dev Mostly exists top Wizard potentially replace
contract modify Kingdom contract rule validation
logic used *future* Kingdoms created World
implement rentry protection send call
charge fee bypass World
listed official World page course
contract never balance
See World create Kingdom ( ) parameter documentation
suppose danger massive deflation inflation could
change real world sanity checks , case
deploy new factory update world
@notice Create new Kingdom Normally called World contract
WARN : validate kingdom Name world arguments
consume 1 , 800 , 000 gas ( ! )
throw error :
rules invalid ( see validate Proposed Throne Rules )
wizard addresses "obviously" wrong
gas quite likely ( perhaps future consider
using solidity libraries reduce Kingdom size ? )
See World create Kingdom ( ) parameter documentation
contract never balance
NB : top Wizard sub Wizard
@title Runs world , collection Kingdoms
top Wizard runs world charge creation
kingdoms become top Wizard kingdom created
much one must pay create new kingdom ( wei )
changed top Wizard
first kingdom number 1; zero th entry dummy
safety , cap high price get
changed top Wizard , though affect
kingdoms created
Helper contract creating Kingdom instances
upgraded top Wizard ( affect existing ones )
Avoids duplicate kingdom names allows searching name
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
Create world kingdoms yet
Costs 1 9M gas deploy
number kingdoms starting 1 since sometimes
useful use zero = invalid Create dummy zero th entry
@return index kingdoms Number found , zero
@notice Check name used kingdom name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
WARN : check name already use;
use `find Kingdom Called ( string ) ` afterwards
Check rules would allowed new custom Kingdom
Typically used calling `create Kingdom ( ) `
much one must pay create new kingdom ( finney )
changed top Wizard
Reject funds sent contract wizards cannot interact
via API able withdraw commission
@notice Create new kingdom using custom rules
@param kingdom Name \
e g "King Ether Throne"
@param starting Claim Price Wei \
much cost first monarch claim throne
( also price death monarch )
@param claim Price Adjust Percent \
Percentage increase claim e g claim price
200 ETH , ` claim Price Adjust Percent` 50 , next
claim price 200 ETH + ( 50% 200 ETH ) = 300 ETH
@param curse Incubation Duration Seconds \
maximum length time monarch rule
curse strikes removed without compensation
@param commission Per Thousand \
much payment given wizards share ,
expressed parts per thousand e g 25 means 25 1000 ,
Caller must include payment equal kingdom Creation Fee Wei
caller become 'sub wizard' earn half
commission charged Kingdom Note however
need call withdraw Funds ( ) Kingdom contract
get commission send automatically
consume 1 , 900 , 000 gas ( ! )
throw error :
name invalid ( see `validate Proposed Kingdom Name ( string ) ` )
name already use ( see `find Kingdom Called ( string ) ` )
rules invalid ( see `validate Proposed Kingdom Rules ( ) ` )
payment low high
insufficient gas ( quite likely ! )
Produces event Kingdom Created Event
@notice Used top Wizard transfer rights future
fees future kingdom wizardships ` replacement` wizard
WARN : original wizard retains ownership past fees
held `funds` mapping , still
withdraw also remain top Wizard existing Kingdoms
Produces event Wizard Replaced Event
@notice Used top Wizard vary fee creating kingdoms
@notice Used top Wizard vary cap claim price
@notice Used top Wizard vary factory contract
used create future Kingdoms
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
perform rule validation
existing kingdom called ` kingdom Name` , create
record mapping name kingdom ` new Kingdom Number`
Throws error existing kingdom (
fuzzily similar see compute Name Fuzzy Hash ) name exists
@title Used testnet allow automated testing internals

King Ether Throne Contracts
Copyright ( c ) 2016 Kieran Elby Released MIT License
Version 0 9 9 2 , July 2016
See also http : www kingoftheether
https : github kieranelby King Ether Throne
file contains number contracts ,
three normally created :
Kingdom = maintains throne kingdom
World = runs world , collection kingdoms
Kingdom Factory = used internally World contract
"Mixin" contracts ( Throne Rules Mixin , Reentry Protector Mixin ,
Careful Sender Mixin , Funds Holder Mixin , Money Rounder Mixin ,
Nameable Mixin ) contain functions data structures used
three main contracts
Exposed Internals Testing contract used automated tests
@title Mixin help avoid recursive call attacks
true inside external function
Mark contract entered external function
Throws exception called twice external Leave ( )
work , Contracts MUST :
call external Enter ( ) start external function
call external Leave ( ) end external function
never use return statements enter leave
never call external function another function
WARN : serious risk contract getting stuck used wrongly
Mark contract left external function
call external Enter ( )
@title Mixin help send ether untrusted addresses
Seems reasonable amount well written fallback function
Send ` value Wei` ether ` Address` , including
` extra Gas Included` gas usual 2300 gas stipend
send call
needs care way tell Address
externally owned another contract sending ether
contract address invoke fallback function;
three implications :
1 ) Danger recursive attack
destination contract's fallback function ( another
contract calls ) may call back contract ( including
fallback function external functions inherited ,
contracts stack ) , leading unexpected behaviour
Mitigations :
protect external functions entry
( see Reentry Protector Mixin ) ;
program defensively ( e g debit balance send )
2 ) Destination fallback function fail
destination contract's fallback function fails , ether
sent may locked sending contract
Unlike errors , cause contract throw
Mitigations :
check return value function ( see )
3 ) Gas usage
destination fallback function consume gas supplied
transaction ( fixed set transaction
starter , though clients good job estimating
problem lottery type contracts one
expensive call receiving contract could 'poison' lottery
contract preventing invoked another person
cannot supply enough gas
Mitigations :
choose sensible value extra Gas Included ( default
2300 gas supplied destination function ) ;
call fails consider whether throw ring fence
funds later withdrawal
Returns :
True send call made throw
error case , longer value Wei
ether Note cannot get return value fallback
function called ( )
False send made destination fallback function
threw error ( ran gas ) hapens , still
value Wei ether destination's actions undone
function normally throw error unless :
enough gas make send call
max call stack depth reached
insufficient ether
@title Mixin help track owns ether allow withdrawals
Record much wei owned address
Obviously , entries MUST backed actual ether
owned contract cannot enforce mixin
@notice Amount ether held ` address`
@notice Send caller ( `msg sender` ) ether
@notice Send ` value Wei` ether owned caller
( `msg sender` ) ` Address` , including ` extra Gas` gas
beyond normal stipend
@dev internal version withdraw Funds ( )
@dev internal version withdraw Funds Advanced ( ) , also used
withdraw Funds RP ( )
@title Mixin help make nicer looking ether amounts
@notice Make ` raw Value Wei` nicer , rounder number
@return value :
larger ` raw Value Wei`
smaller ` raw Value Wei` * 0 999
three significant figures UNLESS
number small large monetary terms
( define 1 finney 10000 ether ) ,
case precision lost
@notice Convert ` value Wei` whole number finney
@return smallest whole number finney equal
greater ` value Wei` converted wei
WARN : May incorrect ` value Wei` 2**254
@title Mixin help allow users name things
String manipulation expensive EVM; keep things short
@notice Check ` name` reasonable choice name
@return True ` name ` meets criteria
, false otherwise :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
least one non punctuation character
Note deliberately exclude characters may cause
security problems websites databases escaping
performed correctly , " '
Apologies lack non English language support
Z
z
space
Extract name bytes ` data` ( presumably `msg data` ) ,
throw exception data expected format
want make easy people name things , even
they're comfortable calling functions contracts
allow names sent fallback function encoded
message data
Unfortunately , way Ethereum Function ABI works means
must careful avoid clashes message data
represents names message data represents call
external function otherwise :
) names usable;
b ) small possibility phishing attack users
tricked using certain names cause external
function call e g data sent contract
keccak256 ( "withdraw Funds ( ) " ) withdrawal occur
require prefix "NAME : " start name ( encoded
ASCII ) sent via fallback function prefix
clash external function signature hashes
e g web3 Ascii ( 'NAME : ' + 'Joe Bloggs' )
WARN : check name "reasonableness";
use validate Name Internal ( )
check prefix present
copy data prefix
Turn short name "fuzzy hash" property
extremely similar names fuzzy hash
useful :
stop people choosing names differ case
punctuation would lead confusion
faciliate searching name without needing exact match
example , names fuzzy hash :
"Banana"
"BANANA"
"Ba na na"
" banana "
"Banana long end ignored"
hand , "Banana1" "A Banana" different
WARN : likely work poorly names meet
validate Name Internal ( ) test
Z
fold z Z
ignore others
@title Mixin help define rules throne
See World create Kingdom ( ) documentation
@title Maintains throne kingdom
e g "King Ether"
World contract used create kingdom , 0x0 none
rules govern kingdom see Throne Rules Mixin
Someone ruled ( ruling ) kingdom
send compensation
name
became ruler
claim price paid ( excluding payment )
compensation sent held far
first ruler number 1; zero th entry dummy entry
top Wizard earns half commission
normally owner World contract
sub Wizard earns half commission
normally creator Kingdom
top Wizard sub Wizard address
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
WARN validate arguments; MUST either call
Kingdom Factory validate Proposed Throne Rules ( ) create
Kingdom via Kingdom Factory World's create Kingdom ( )
See World create Kingdom ( ) parameter documentation
number monarchs starting 1; sometimes useful
use zero = invalid , put dummy entry number 0
zero th entry invalid
False either monarchs , latest monarch
reigned long struck curse
possible , think miners reject blocks
timestamps go backwards ? drift possible
needs handling unsigned overflow audit checks
@notice much must pay claim throne , wei
danger overflow claim price never gets high
@notice much must pay claim throne , finney
@notice Check name used monarch name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
Get details latest monarch ( even dead )
expose externally returning structs well
supported ABI ( strange monarchs Number array works
fine though ) Note reference returned writable
used update details latest monarch
WARN : check number Monarchs ( ) 0 first
@notice Claim throne sending funds contract
future compensation earned sent sender's
address ( `msg sender` )
Sending contract recommended unless know
( tested )
message data supplied , throne claimed
name "Anonymous" supply name , send data encoded
using web3 Ascii ( 'NAME : ' + 'your chosen valid name' )
Sender must include payment equal current Claim Price Wei ( )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event`
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Claim throne given ` monarch Name`
future compensation earned sent caller's
address ( `msg sender` )
Caller must include payment equal current Claim Price Wei ( )
Calling contract recommended unless know
( tested )
consume ~300 , 000 gas
throw error :
name invalid ( see `validate Proposed Monarch Name ( string ) ` )
payment low high
Produces events :
`Throne Claimed Event
`Compensation Sent Event` `Compensation Fail Event`
`Commission Earned Event`
@notice Used either top Wizard sub Wizard transfer
rights future commissions ` replacement` wizard
WARN : original wizard retains ownership past
commission held `funds` mapping ,
still withdraw
Produces event Wizard Replaced Event
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
dead men get compensation
case teeny excess , use official price
since determine new claim price , paid Wei
Careful top Wizard sub Wizard address ,
case must replace
Allow commission funds build contract wizards
withdraw ( carefully ring fenced )
give sub Wizard "odd" single wei
Send compensation latest monarch ( hold funds
cannot fault current caller )
record compensated
WARN : latest monarch contract whose fallback
function needs 25300 gas
receive compensation automatically
happen latest monarch contract
whose fallback function failed ran gas ( despite
us including fair amount gas )
throw since want throne get
'stuck' ( new usurpers fault ) instead save
funds could send claimed later
monarch contract would need designed
call withdraw Funds Advanced ( ) function mind
@title Used World contract create Kingdom instances
@dev Mostly exists top Wizard potentially replace
contract modify Kingdom contract rule validation
logic used *future* Kingdoms created World
implement rentry protection send call
charge fee bypass World
listed official World page course
contract never balance
See World create Kingdom ( ) parameter documentation
suppose danger massive deflation inflation could
change real world sanity checks , case
deploy new factory update world
@notice Create new Kingdom Normally called World contract
WARN : validate kingdom Name world arguments
consume 1 , 800 , 000 gas ( ! )
throw error :
rules invalid ( see validate Proposed Throne Rules )
wizard addresses "obviously" wrong
gas quite likely ( perhaps future consider
using solidity libraries reduce Kingdom size ? )
See World create Kingdom ( ) parameter documentation
contract never balance
NB : top Wizard sub Wizard
@title Runs world , collection Kingdoms
top Wizard runs world charge creation
kingdoms become top Wizard kingdom created
much one must pay create new kingdom ( wei )
changed top Wizard
first kingdom number 1; zero th entry dummy
safety , cap high price get
changed top Wizard , though affect
kingdoms created
Helper contract creating Kingdom instances
upgraded top Wizard ( affect existing ones )
Avoids duplicate kingdom names allows searching name
NB : also `funds` mapping Funds Holder Mixin ,
rentry Protector Reentry Protector Mixin
NB : also `Funds Withdrawn Event` Funds Holder Mixin
Create world kingdoms yet
Costs 1 9M gas deploy
number kingdoms starting 1 since sometimes
useful use zero = invalid Create dummy zero th entry
@return index kingdoms Number found , zero
@notice Check name used kingdom name
@return True name satisfies criteria :
fewer 1 character
25 characters
characters :
"roman" alphabet letters ( Z z )
western digits ( 0 9 )
"safe" punctuation : ! ( ) SPACE
WARN : check name already use;
use `find Kingdom Called ( string ) ` afterwards
Check rules would allowed new custom Kingdom
Typically used calling `create Kingdom ( ) `
much one must pay create new kingdom ( finney )
changed top Wizard
Reject funds sent contract wizards cannot interact
via API able withdraw commission
@notice Create new kingdom using custom rules
@param kingdom Name \
e g "King Ether Throne"
@param starting Claim Price Wei \
much cost first monarch claim throne
( also price death monarch )
@param claim Price Adjust Percent \
Percentage increase claim e g claim price
200 ETH , ` claim Price Adjust Percent` 50 , next
claim price 200 ETH + ( 50% 200 ETH ) = 300 ETH
@param curse Incubation Duration Seconds \
maximum length time monarch rule
curse strikes removed without compensation
@param commission Per Thousand \
much payment given wizards share ,
expressed parts per thousand e g 25 means 25 1000 ,
Caller must include payment equal kingdom Creation Fee Wei
caller become 'sub wizard' earn half
commission charged Kingdom Note however
need call withdraw Funds ( ) Kingdom contract
get commission send automatically
consume 1 , 900 , 000 gas ( ! )
throw error :
name invalid ( see `validate Proposed Kingdom Name ( string ) ` )
name already use ( see `find Kingdom Called ( string ) ` )
rules invalid ( see `validate Proposed Kingdom Rules ( ) ` )
payment low high
insufficient gas ( quite likely ! )
Produces event Kingdom Created Event
@notice Used top Wizard transfer rights future
fees future kingdom wizardships ` replacement` wizard
WARN : original wizard retains ownership past fees
held `funds` mapping , still
withdraw also remain top Wizard existing Kingdoms
Produces event Wizard Replaced Event
@notice Used top Wizard vary fee creating kingdoms
@notice Used top Wizard vary cap claim price
@notice Used top Wizard vary factory contract
used create future Kingdoms
Make easy people pay using whole number finney ,
could teeny bit higher raw wei value
perform rule validation
existing kingdom called ` kingdom Name` , create
record mapping name kingdom ` new Kingdom Number`
Throws error existing kingdom (
fuzzily similar see compute Name Fuzzy Hash ) name exists
@title Used testnet allow automated testing internals

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

fork oracle use
recipient 1 % fee ETC side
following happens forked chain :
100 % forwarded provided destination ETH
following happens classic chain :
1 % forwarded fee recipient
99 % forwarded provided destination ETC
accept value transfers

fork oracle use
recipient 1 % fee ETC side
following happens forked chain :
100 % forwarded provided destination ETH
following happens classic chain :
1 % forwarded fee recipient
99 % forwarded provided destination ETC
accept value transfers

Single owner wallet keeps ETC ETH separately helps preventing
replaying , incoming outgoing transactions
instantiated , contract sets three addressed :
1 Address used send receive ETC address reject
incoming ETH transfers , ETH balance always zero;
2 Address used send receive ETH address reject
incoming ETC transfers , ETC balance always zero;
3 Address used receive payments flavors ether even
unsplit replayable ETC+ETH payments Ether coming address
automatically classified distributed among address 1 address 2
set true forked branch false classic branch
Address ETC subwallet
Address ETH subwallet
Log address ETC subwallet
Log address ETH subwallet
Instantiate contract
Check whether fork branch classic one
Create ETC subwallet
Create ETH subwallet
Log address ETC subwallet
Log address ETH subwallet
Distribute pending balance ETC ETH subwallets
Send ETH ETH subwallet
Send ETC ETC subwallet
Wallet contract operates "right" branch
Owner wallet
set true currently "right" branch
blockchain , e branch wallet operating
Instantiate contract
@param owner owner contract
@is Right Branch whether currently "right" branch
accept money "right" branch
Execute transaction using money wallet
@param transaction destination
@param value transaction value
@param data transaction data
Execute transaction using money wallet
@param transaction destination
@param value transaction value
@param data transaction data
Simple smart contract allows anyone tell currently
"right" branch blockchain
set true currently "right" branch
blockchain

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title ERC721 Non Fungible Token Standard basic interface
dev see https : github ethereum EIPs blob master EIPS eip 721 md
title Safe Math
dev Math operations safety checks throw error
Utility library inline functions addresses
Returns whether target address contract
dev function return false invoked constructor contract ,
code actually created constructor finishes
param addr address check
return whether target address contract
first version simple ACL Permission Management System
might differentiate Permission Management Systems therefore restrictive following points :
Every User one Role
new Roles "Positions" generated
Therefore possible Roles must defined beginning
title ERC721 Non Fungible Token Standard basic implementation
dev edited verison Open Zepplin implementation
dev see https : github ethereum EIPs blob master EIPS eip 721 md
dev edited mint & Approved Owner modifiers
dev Guarantees msg sender owner given token
param token Id uint256 ID token validate ownership belongs msg sender
dev Checks msg sender transfer token , owner , approved , operator
param token Id uint256 ID token validate
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
dev Gets owner specified token ID
param token Id uint256 ID token query owner
return owner address currently marked owner given token ID
require ( owner ! = address ( 0 ) ) ;
dev Returns whether specified token exists
param token Id uint256 ID token query existence
return whether token exists
dev Approves another address transfer given token ID
dev zero address indicates approved address
dev one approved address per token given time
dev called token owner approved operator
param address approved given token ID
param token Id uint256 ID token approved
dev Gets approved address token ID , zero address set
param token Id uint256 ID token query approval
return address currently approved given token ID
dev Sets unsets approval given operator
dev operator allowed transfer tokens sender behalf
param operator address set approval
param approved representing status approval set
dev Transfers ownership given token ID another address
dev Usage method discouraged , use `safe Transfer From` whenever possible
dev Requires msg sender owner , approved , operator
param current owner token
param address receive ownership given token ID
param token Id uint256 ID token transferred
dev Returns whether given spender transfer given token ID
param spender address spender query
param token Id uint256 ID token transferred
return bool whether msg sender approved given token ID ,
operator owner , owner token
dev Internal function mint new token
dev Reverts given token ID already exists
param address minted token
param token Id uint256 ID token minted msg sender
dev check ( 2 ) checks msg sender == ADMIN
dev Internal function burn specific token
dev Reverts token exist
param token Id uint256 ID token burned msg sender
dev Internal function clear current approval given token ID
dev Reverts given address indeed owner token
param owner owner token
param token Id uint256 ID token transferred
dev Internal function add token ID list given address
param address representing new owner given token ID
param token Id uint256 ID token added tokens list given address
dev Internal function remove token ID list given address
param address representing previous owner given token ID
param token Id uint256 ID token removed tokens list given address
github ethereum EIPs blob master EIPS eip 721 md
File : contracts Safe Math sol
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
File : contracts Address Utils sol
XXX Currently better way check contract address
check size code address
See https : ethereum stackexchange 14016 36603
details works
TODO Check Serenity release , addresses
contracts
solium disable line security inline assembly
File : contracts acl sol
File : contracts ERC721Basic Token sol
github ethereum EIPs blob master EIPS eip 721 md
Mapping token ID owner
Mapping token ID approved address
Mapping owner number owned token
Mapping owner operator approvals
File : contracts testreg sol
@param
File : contracts update sol
File : contracts blooming Pool sol
@dev altered version Open Zepplin's 'Split Payment' contract
File : contracts buyable sol

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
ether sent address , send back
Give creator initial tokens , 8 zero 8 Decimals
Update total supply , , 8 zero 8 Decimals
Token Name
Amount decimals display purposes
Token Symbol

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

Credit : Gerhard Wagner
Orginal source : https : medium @gerhard wagner phenomena smart contract honeypots 755c1f943f7b
medium @gerhard wagner phenomena smart contract honeypots 755c1f943f7b

Credit : Ethereum
Orginal source : https : www ethereum org token
www ethereum org token
wei
Avoid overflows

Credit : Ethereum
Orginal source : https : www ethereum org token
www ethereum org token
wei
Avoid overflows
Answer : Set gas limits

wei
Avoid overflows

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

dev Provides information current execution context , including
sender transaction data generally available
via msg sender msg data , accessed direct
manner , since dealing meta transactions account sending
paying execution may actual sender ( far application
concerned )
contract required intermediate , library like contracts
dev Collection functions related address type
dev Returns true `account` contract
[IMPORTANT]
unsafe assume address function returns
false externally owned account ( EOA ) contract
Among others , `is Contract` return false following
types addresses :
externally owned account
contract construction
address contract created
address contract lived , destroyed
dev Replacement Solidity's `transfer` : sends `amount` wei
`recipient` , forwarding available gas reverting errors
https : eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
certain opcodes , possibly making contracts go 2300 gas limit
imposed `transfer` , making unable receive funds via
`transfer` {send Value} removes limitation
https : diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
IMPORTANT : control transferred `recipient` , care must
taken create reentrancy vulnerabilities Consider using
{Reentrancy Guard}
https : solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
dev Performs Solidity function call using low level `call`
plain`call` unsafe replacement function call : use
function instead
`target` reverts revert reason , bubbled
function ( like regular Solidity function calls )
Returns raw returned data convert expected return value ,
use https : solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
Requirements :
`target` must contract
calling `target` `data` must revert
Available since v3 1
dev {xref Address function Call address bytes }[`function Call`] ,
`error Message` fallback revert reason `target` reverts
Available since v3 1
dev {xref Address function Call address bytes }[`function Call`] ,
also transferring `value` wei `target`
Requirements :
calling contract must ETH balance least `value`
called Solidity function must `payable`
Available since v3 1
dev {xref Address function Call Value address bytes uint256 }[`function Call Value`] ,
`error Message` fallback revert reason `target` reverts
Available since v3 1
dev {xref Address function Call address bytes }[`function Call`] ,
performing static call
Available since v3 3
dev {xref Address function Call address bytes string }[`function Call`] ,
performing static call
Available since v3 3
dev {xref Address function Call address bytes }[`function Call`] ,
performing delegate call
Available since v3 4
dev {xref Address function Call address bytes string }[`function Call`] ,
performing delegate call
Available since v3 4
dev String operations
dev Converts `uint256` ASCII `string` decimal representation
dev Converts `uint256` ASCII `string` hexadecimal representation
dev Converts `uint256` ASCII `string` hexadecimal representation fixed length
dev Contract module provides basic access control mechanism ,
account ( owner ) granted exclusive access
specific functions
default , owner account one deploys contract
later changed {transfer Ownership}
module used inheritance make available modifier
`only Owner` , applied functions restrict use
owner
dev Initializes contract setting deployer initial owner
dev Returns address current owner
dev Throws called account owner
dev Leaves contract without owner possible call
`only Owner` functions anymore called current owner
NOTE : Renouncing ownership leave contract without owner ,
thereby removing functionality available owner
dev Transfers ownership contract new account ( `new Owner` )
called current owner
dev Interface ERC165 standard , defined
https : eips ethereum org EIPS eip 165[EIP]
Implementers declare support contract interfaces ,
queried others ( {ERC165Checker} )
implementation , see {ERC165}
dev Returns true contract implements interface defined
`interface Id` See corresponding
https : eips ethereum org EIPS eip 165 interfaces identified[EIP section]
learn ids created
function call must use less 30 000 gas
dev Required interface ERC721 compliant contract
dev Emitted `token ID` token transferred `from` `to`
dev Emitted `owner` enables `approved` manage `token ID` token
dev Emitted `owner` enables disables ( `approved` ) `operator` manage assets
dev Returns number tokens ``owner``'s account
dev Returns owner `token ID` token
Requirements :
`token ID` must exist
dev Safely transfers `token ID` token `from` `to` , checking first contract recipients
aware ERC721 protocol prevent tokens forever locked
Requirements :
`from` cannot zero address
`to` cannot zero address
`token ID` token must exist owned `from`
caller `from` , must allowed move token either {approve} {set Approval All}
`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
Emits {Transfer} event
dev Transfers `token ID` token `from` `to`
WARNING : Usage method discouraged , use {safe Transfer From} whenever possible
Requirements :
`from` cannot zero address
`to` cannot zero address
`token ID` token must owned `from`
caller `from` , must approved move token either {approve} {set Approval All}
Emits {Transfer} event
dev Gives permission `to` transfer `token ID` token another account
approval cleared token transferred
single account approved time , approving zero address clears previous approvals
Requirements :
caller must token approved operator
`token ID` must exist
Emits {Approval} event
dev Returns account approved `token ID` token
Requirements :
`token ID` must exist
dev Approve remove `operator` operator caller
Operators call {transfer From} {safe Transfer From} token owned caller
Requirements :
`operator` cannot caller
Emits {Approval All} event
dev Returns `operator` allowed manage assets `owner`
See {set Approval All}
dev Safely transfers `token ID` token `from` `to`
Requirements :
`from` cannot zero address
`to` cannot zero address
`token ID` token must exist owned `from`
caller `from` , must approved move token either {approve} {set Approval All}
`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
Emits {Transfer} event
dev Implementation {IERC165} interface
Contracts want implement ERC165 inherit contract override {supports Interface} check
additional interface id supported example :
```solidity
function supports Interface ( bytes4 interface Id ) public view virtual override returns ( bool ) {
return interface Id == type ( Interface ) interface Id || super supports Interface ( interface Id ) ;
Alternatively , {ERC165Storage} provides easier use expensive implementation
dev See {IERC165 supports Interface}
title ERC 721 Non Fungible Token Standard , optional metadata extension
dev See https : eips ethereum org EIPS eip 721
dev Returns token collection name
dev Returns token collection symbol
dev Returns Uniform Resource Identifier ( URI ) `token ID` token
dev Whenever {IERC721} `token ID` token transferred contract via {IERC721 safe Transfer From}
`operator` `from` , function called
must return Solidity selector confirm token transfer
value returned interface implemented recipient , transfer reverted
selector obtained Solidity `IERC721 ERC721Received selector`
dev Implementation https : eips ethereum org EIPS eip 721[ERC721] Non Fungible Token Standard , including
Metadata extension , including Enumerable extension , available separately
{ERC721Enumerable}
dev Initializes contract setting `name` `symbol` token collection
dev See {IERC165 supports Interface}
dev See {IERC721 balance Of}
dev See {IERC721 owner Of}
dev See {IERC721Metadata name}
dev See {IERC721Metadata symbol}
dev See {IERC721Metadata token URI}
dev Base URI computing {token URI} Empty default , overriden
child contracts
dev See {IERC721 approve}
dev See {IERC721 get Approved}
dev See {IERC721 set Approval All}
dev See {IERC721 Approved All}
dev See {IERC721 transfer From}
dev See {IERC721 safe Transfer From}
dev See {IERC721 safe Transfer From}
dev Safely transfers `token ID` token `from` `to` , checking first contract recipients
aware ERC721 protocol prevent tokens forever locked
` data` additional data , specified format sent call `to`
internal function equivalent {safe Transfer From} , used e g
implement alternative mechanisms perform token transfer , signature based
Requirements :
`from` cannot zero address
`to` cannot zero address
`token ID` token must exist owned `from`
`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
Emits {Transfer} event
dev Returns whether `token ID` exists
Tokens managed owner approved accounts via {approve} {set Approval All}
Tokens start existing minted ( ` mint` ) ,
stop existing burned ( ` burn` )
dev Returns whether `spender` allowed manage `token ID`
Requirements :
`token ID` must exist
dev Safely mints `token ID` transfers `to`
Requirements :
`token ID` must exist
`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
Emits {Transfer} event
dev {xref ERC721 safe Mint address uint256 }[` safe Mint`] , additional `data` parameter
forwarded {IERC721Receiver ERC721Received} contract recipients
dev Mints `token ID` transfers `to`
WARNING : Usage method discouraged , use { safe Mint} whenever possible
Requirements :
`token ID` must exist
`to` cannot zero address
Emits {Transfer} event
dev Destroys `token ID`
approval cleared token burned
Requirements :
`token ID` must exist
Emits {Transfer} event
dev Transfers `token ID` `from` `to`
opposed {transfer From} , imposes restrictions msg sender
Requirements :
`to` cannot zero address
`token ID` token must owned `from`
Emits {Transfer} event
dev Approve `to` operate `token ID`
Emits {Approval} event
dev Internal function invoke {IERC721Receiver ERC721Received} target address
call executed target address contract
param address representing previous owner given token ID
param target address receive tokens
param token ID uint256 ID token transferred
param data bytes optional data send along call
return bool whether call correctly returned expected magic value
dev Hook called token transfer includes minting
burning
Calling conditions :
`from` `to` non zero , ``from``'s `token ID`
transferred `to`
`from` zero , `token ID` minted `to`
`to` zero , ``from``'s `token ID` burned
`from` cannot zero address
`to` cannot zero address
learn hooks , head xref : ROOT : extending contracts adoc using hooks[Using Hooks]
dev Emitted `new Admin Role` set ``role``'s admin role , replacing `previous Admin Role`
`DEFAULT ADMIN ROLE` starting admin roles , despite
{Role Admin Changed} emitted signaling
Available since v3 1
dev Emitted `account` granted `role`
`sender` account originated contract call , admin role
bearer except using { setup Role}
dev Emitted `account` revoked `role`
`sender` account originated contract call :
using `revoke Role` , admin role bearer
using `renounce Role` , role bearer ( e `account` )
dev Returns `true` `account` granted `role`
dev Returns admin role controls `role` See {grant Role}
{revoke Role}
change role's admin , use { set Role Admin}
dev Grants `role` `account`
`account` already granted `role` , emits {Role Granted}
event
Requirements :
caller must ``role``'s admin role
dev Revokes `role` `account`
`account` granted `role` , emits {Role Revoked} event
Requirements :
caller must ``role``'s admin role
dev Revokes `role` calling account
Roles often managed via {grant Role} {revoke Role} : function's
purpose provide mechanism accounts lose privileges
compromised ( trusted device misplaced )
calling account granted `role` , emits {Role Revoked}
event
Requirements :
caller must `account`
dev Grants `role` `account`
`account` already granted `role` , emits {Role Granted}
event Note unlike {grant Role} , function perform
checks calling account
[WARNING]
function called constructor setting
initial roles system
Using function way effectively circumventing admin
system imposed {Access Control}
dev Sets `admin Role` ``role``'s admin role
Emits {Role Admin Changed} event
SPDX License Identifier : GPL 3 0
silence state mutability warning without generating bytecode see https : github ethereum solidity issues 2691
method relies extcodesize , returns 0 contracts
construction , since code stored end
constructor execution
solhint disable next line inline assembly
eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
solhint disable next line avoid low level calls , avoid call value
solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
solhint disable next line avoid low level calls
solhint disable next line avoid low level calls
solhint disable next line avoid low level calls
Look revert reason bubble present
easiest way bubble revert reason using memory via assembly
solhint disable next line inline assembly
Inspired Oraclize API's implementation MIT licence
https : github oraclize ethereum api blob b42146b063c7d6ee1358846c198246239e9360e8 oraclize API 0 4 25 sol
eips ethereum org EIPS eip 165[EIP]
eips ethereum org EIPS eip 165 interfaces identified[EIP section]
eips ethereum org EIPS eip 721
eips ethereum org EIPS eip 721[ERC721] Non Fungible Token Standard , including
Token name
Token symbol
Mapping token ID owner address
Mapping owner address token count
Mapping token ID approved address
Mapping owner operator approvals
solhint disable next line max line length
Clear approvals
Clear approvals previous owner
solhint disable next line inline assembly
Base Token URI

Public functions
Internal functions
Web3 call functions
Public functions
Internal functions
Web3 call functions
@title Multisignature wallet Allows multiple parties agree transactions execution
@ Stefan George stefan george@consensys net
@dev Fallback function allows deposit ether
@dev Contract constructor sets initial owners required number confirmations
@param owners List initial owners
@param required Number required confirmations
@dev Allows add new owner Transaction sent wallet
@param owner Address new owner
@dev Allows remove owner Transaction sent wallet
@param owner Address owner
@dev Allows replace owner new owner Transaction sent wallet
@param owner Address owner replaced
@param owner Address new owner
@dev Allows change number required confirmations Transaction sent wallet
@param required Number required confirmations
@dev Allows owner submit confirm transaction
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Allows owner confirm transaction
@param transaction Id Transaction ID
@dev Allows owner revoke confirmation transaction
@param transaction Id Transaction ID
@dev Allows anyone execute confirmed transaction
@param transaction Id Transaction ID
@dev Returns confirmation status transaction
@param transaction Id Transaction ID
@return Confirmation status
@dev Adds new transaction transaction mapping , transaction exist yet
@param destination Transaction target address
@param value Transaction ether value
@param data Transaction data payload
@return Returns transaction ID
@dev Returns number confirmations transaction
@param transaction Id Transaction ID
@return Number confirmations
@dev Returns total number transactions filers applied
@param pending Include pending transactions
@param executed Include executed transactions
@return Total number transactions filters applied
@dev Returns list owners
@return List owner addresses
@dev Returns array owner addresses , confirmed transaction
@param transaction Id Transaction ID
@return Returns array owner addresses
@dev Returns list transaction IDs defined range
@param Index start position transaction array
@param Index end position transaction array
@param pending Include pending transactions
@param executed Include executed transactions
@return Returns array transaction IDs
@title Multisignature wallet daily limit Allows owner withdraw daily limit without multisig
@ Stefan George stefan george@consensys net
@dev Contract constructor sets initial owners , required number confirmations daily withdraw limit
@param owners List initial owners
@param required Number required confirmations
@param daily Limit Amount wei , withdrawn without confirmations daily basis
@dev Allows change daily limit Transaction sent wallet
@param daily Limit Amount wei
@dev Allows anyone execute confirmed transaction ether withdraws daily limit reached
@param transaction Id Transaction ID
@dev Returns amount within daily limit resets spent Today one day
@param amount Amount withdraw
@return Returns amount daily limit
@dev Returns maximum withdraw amount
@return Returns amount

Submitted verification hecoinfo
dev Hook called transfer tokens includes
minting burning
Calling conditions :
`from` `to` non zero , `amount` ``from``'s tokens
transferred `to`
`from` zero , `amount` tokens minted `to`
`to` zero , `amount` ``from``'s tokens burned
`from` `to` never zero
learn hooks , head xref : ROOT : extending contracts adoc using hooks[Using Hooks]
dev Returns cap token's total supply
HD Token
Minte Token Account
param account minter
param amount amount
Add minter
param minter minter
Remove minter
param minter minter
Set new governance
param pending Gov new governance
lets msg sender accept governance
dev See {ERC20 Token Transfer}
Requirements :
minted tokens must cause total supply go cap
solhint disable previous line empty blocks
Solidity automatically asserts dividing 0
solhint disable next line inline assembly
solhint disable next line avoid low level calls
Return data optional
solhint disable next line max line length
Modifiers
minting tokens

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

dev Interface ERC20 standard defined EIP
dev Returns amount tokens existence
dev Returns amount tokens owned `account`
dev Moves `amount` tokens caller's account `recipient`
Returns boolean value indicating whether operation succeeded
Emits {Transfer} event
dev Returns remaining number tokens `spender`
allowed spend behalf `owner` {transfer From}
zero default
value changes {approve} {transfer From} called
dev Sets `amount` allowance `spender` caller's tokens
Returns boolean value indicating whether operation succeeded
IMPORTANT : Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race
condition first reduce spender's allowance 0 set
desired value afterwards :
https : github ethereum EIPs issues 20 issuecomment 263524729
Emits {Approval} event
dev Moves `amount` tokens `sender` `recipient` using
allowance mechanism `amount` deducted caller's
allowance
Returns boolean value indicating whether operation succeeded
Emits {Transfer} event
dev Emitted `value` tokens moved one account ( `from` )
another ( `to` )
Note `value` may zero
dev Emitted allowance `spender` `owner` set
call {approve} `value` new allowance
dev Wrappers Solidity's arithmetic operations added overflow
checks
Arithmetic operations Solidity wrap overflow easily result
bugs , programmers usually assume overflow raises
error , standard behavior high level programming languages
`Safe Math` restores intuition reverting transaction
operation overflows
Using library instead unchecked operations eliminates entire
class bugs , recommended use always
dev Collection functions related address type
dev Returns true `account` contract
[IMPORTANT]
unsafe assume address function returns
false externally owned account ( EOA ) contract
Among others , `is Contract` return false following
types addresses :
externally owned account
contract construction
address contract created
address contract lived , destroyed
dev Replacement Solidity's `transfer` : sends `amount` wei
`recipient` , forwarding available gas reverting errors
https : eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
certain opcodes , possibly making contracts go 2300 gas limit
imposed `transfer` , making unable receive funds via
`transfer` {send Value} removes limitation
https : diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
IMPORTANT : control transferred `recipient` , care must
taken create reentrancy vulnerabilities Consider using
{Reentrancy Guard}
https : solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
dev Performs Solidity function call using low level `call`
plain`call` unsafe replacement function call : use
function instead
`target` reverts revert reason , bubbled
function ( like regular Solidity function calls )
Returns raw returned data convert expected return value ,
use https : solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
Requirements :
`target` must contract
calling `target` `data` must revert
Available since v3 1
dev {xref Address function Call address bytes }[`function Call`] ,
`error Message` fallback revert reason `target` reverts
Available since v3 1
dev {xref Address function Call address bytes }[`function Call`] ,
also transferring `value` wei `target`
Requirements :
calling contract must ETH balance least `value`
called Solidity function must `payable`
Available since v3 1
dev {xref Address function Call Value address bytes uint256 }[`function Call Value`] ,
`error Message` fallback revert reason `target` reverts
Available since v3 1
dev Provides information current execution context , including
sender transaction data generally available
via msg sender msg data , accessed direct
manner , since dealing GSN meta transactions account sending
paying execution may actual sender ( far application
concerned )
contract required intermediate , library like contracts
github ethereum EIPs issues 20 issuecomment 263524729
According EIP 1052 , 0x0 value returned yet created accounts
0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 returned
accounts without code , e `keccak256 ( '' ) `
solhint disable next line inline assembly
eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
solhint disable next line avoid low level calls , avoid call value
solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
solhint disable next line avoid low level calls
Look revert reason bubble present
easiest way bubble revert reason using memory via assembly
solhint disable next line inline assembly
silence state mutability warning without generating bytecode see https : github ethereum solidity issues 2691
Initially assign tokens contract's creator
deduct sender's balance
add recipient's balance
3% 3 100 value leftvalue
0 03% 3 10000 value leftvalue

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
title Claimable
dev Extension Ownable contract , ownership needs claimed
allows new owner accept transfer
dev Modifier throws called account pending Owner
dev Allows current owner set pending Owner address
param new Owner address transfer ownership
dev Allows pending Owner address finalize transfer
title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
dev responsible calling withdraw function
dev token transfer token Address 0x0000
param destination receiver token eth
param amount amount ETH Tokens
param token Address actual token address 0x000 case eth transfer
dev fallback function enable ETH transfer
dev setter withdraw creator ( responsible calling withdraw function )
dev withdraw function send token addresses eth amounts list receivers
param destinations batch list token eth receivers
param amounts batch list values eth tokens
param token Addresses token transfered case eth leave 0x address
File : zeppelin solidity contracts ownership Ownable sol
File : zeppelin solidity contracts ownership Claimable sol
File : zeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : zeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts Withdrawals sol
itterate receivers
eth transfer
erc 20 transfer
emit event cases

title Multi Sig
dev Simple Multi Sig using chain signing
Julien Niset julien@argent xyz
dev Throws calling account multisig
dev Mainly used enforcing use internal functions "execute" function
dev Constructor
param threshold threshold multisig
param owners initial set owners multisig
dev entry point multisig method execute transaction provided
receieved enough signatures wallet owners
param destination address transaction execute
param value value parameter transaction execute
param data data parameter transaction execute
param signatures Concatenated signatures ordered based increasing signer's address
dev Adds owner multisig method called multisig
( e must go execute method confirmed owners )
param owner address new owner
dev Removes owner multisig method called multisig
( e must go execute method confirmed owners )
param owner address owner removed
dev Changes threshold multisig method called multisig
( e must go execute method confirmed owners )
param new Threshold new threshold
dev Parses signatures extract ( r , , v ) signature given index
signature {bytes32 r}{bytes32 s}{uint8 v} compact form signatures concatenated
param signatures concatenated signatures
param index signature read ( 0 , 1 , 2 , )
dev Fallback function allow multisig receive ETH , fail implemented
Copyright ( C ) 2018 Argent Labs Ltd https : argent xyz
program free software : redistribute modify
terms GNU General Public License published
Free Software Foundation , either version 3 License ,
( option ) later version
program distributed hope useful ,
WITHOUT WARRANTY; without even implied warranty
MERCHANTABILITY FITNESS PARTICULAR PURPOSE See
GNU General Public License details
received copy GNU General Public License
along program , see http : www gnu org licenses
Incrementing counter prevent replay attacks
threshold
number owners
Mapping check address owner
Events
make sure signers different
solium disable next line security call value
enough signatures threshold , transaction executed
jump 32 ( 0x20 ) first slot bytes contains length
jump 65 ( 0x41 ) per signature
v load 32 bytes ending v ( first 31 come ) tehn apply mask
solium disable next line security inline assembly

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
New ERC223 contract interface
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
dev Approve passed address spend specified amount tokens behalf msg sender
param spender address spend funds
param value amount tokens spent
dev Function check amount tokens owner allowed spender
param owner address address owns funds
param spender address address spend funds
return uint256 specifying amount tokens still available spender
dev Burns specific amount tokens
param value amount token burned
title Mintable token
dev Simple ERC20 Token example , mintable token creation
dev Function mint tokens
param address receive minted tokens
param amount amount tokens mint
return boolean indicates operation successful
dev Function stop minting new tokens
return True operation successful
contract defining owener transfer owenership others
contract creator owner
Check needed sub ( allowance , value ) already throw condition met
require ( value = allowance ) ;
@dev function increase Approval spender
@dev function decrease Approval spender
@dev function called user another contract wants transfer funds
Function called user another contract wants transfer funds
Standard function transfer similar ERC20 transfer data
Added due backwards compatibility reasons
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
assemble given address bytecode bytecode exists addr contract
retrieve size code target address , needs assembly
function called transaction target address
function called transaction target contract
@dev contract burn tokens reduce total Supply tokens
need require value = total Supply , since would imply
sender's balance greater total Supply , *should* assertion failure
( balance ( msg sender ) value ) revert ( ) ;
( safe Add ( circulating Coins , amount ) total Supply ) revert ( ) ;
Send tokens owner

Public variables token
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

Public variables token
NOTE :
following variables OPTIONAL vanities One include
allow one customise token contract & way influences core functionality
wallets interfaces might even bother look information
Approves calls receiving contract
@return total amount tokens
@param owner address balance retrieved
@return balance
@notice send ` value` token ` to` `msg sender`
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice send ` value` token ` to` ` from` condition approved ` from`
@param address sender
@param address recipient
@param value amount token transferred
@return Whether transfer successful
@notice `msg sender` approves ` addr` spend ` value` tokens
@param spender address account able transfer tokens
@param value amount wei approved transfer
@return Whether approval successful
@param owner address account owning tokens
@param spender address account able transfer tokens
@return Amount remaining tokens allowed spent
Default assumes total Supply can't max ( 2^256 1 )
token leaves total Supply issue tokens time goes , need check wrap
Replace one instead
( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
Replace line following want protect wrapping uints
( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
Token Fork Pundi Xlabs proprietary rights coded ECR20 algorithm
Token Name
many decimals show standard complicant keep 18
identifier : eg NPXC , NPXS etc
many units coin bought 1 ETH ?
WEI smallest unit ETH ( equivalent cent USD satoshi BTC ) We'll store total ETH raised via ICO
raised ETH go ?
constructor function
means following function name match contract name declared
Give creator rights initial NPXC tokens
Update total supply ( 1000 example )
Set name display purposes
Amount decimals display purposes
Set symbol display purposes
Set price token ICO
owner contract gets ETH
Broadcast message blockchain
Transfer ether funds Wallet
call receive Approval function contract want notified crafts function signature manually one include contract
receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
assumed call *should* succeed , otherwise one would use vanilla approve instead

FILE INFORMATION
file : Owned sol
version : 1 1
: Anton Jurisevic
Dominic Romanowski
date : 2018 2 26
MODULE DESCRIPTION
Owned contract , inherited contracts
Requires owner explicitly set constructor
Provides Owner access modifier
change owner , current owner must nominate next owner ,
accept nomination nomination
cancelled accepted new owner
previous owner change nomination ( setting 0 )
title contract owner
notice Contract ownership transferred first nominating new owner ,
must accept ownership , prevents accidental incorrect ownership transfers
dev Owned Constructor
notice Nominate new owner contract
dev current owner may nominate new owner
notice Accept nomination owner
FILE INFORMATION
file : Self Destructible sol
version : 1 2
: Anton Jurisevic
date :
MODULE DESCRIPTION
contract allows inheriting contract destroyed
owner indicates intention waits period
without changing mind ether contained contract
forwarded nominated beneficiary upon destruction
title contract destroyed owner delay elapses
* @dev Constructor
* @param owner account controls contract
* @notice Set beneficiary address contract
* @dev contract owner may call provided beneficiary must non null
* @param beneficiary address pay eth contained contract upon self destruction
* @notice Begin self destruction counter contract
* delay elapsed , contract may self destructed
* @dev contract owner may call
* @notice Terminate reset self destruction timer
* @dev contract owner may call
* @notice self destruction delay elapsed , destroy contract
* remit ether owns beneficiary address
* @dev contract owner may call
FILE INFORMATION
file : Pausable sol
version : 1 0
: Kevin Brown
date :
MODULE DESCRIPTION
contract allows inheriting contract marked
paused also defines modifier used
inheriting contract prevent actions paused
title contract paused owner
dev Constructor
param owner account controls contract
notice Change paused state contract
dev contract owner may call
FILE INFORMATION
file : Safe Decimal Math sol
version : 1 0
: Anton Jurisevic
date : 2018 2 5
checked : Mike Spain
approved : Samuel Brooks
MODULE DESCRIPTION
fixed point decimal library provides basic mathematical
operations , checks unsafe arguments , example
would lead overflows
Exceptions thrown whenever unsafe operations
occur
title Safely manipulate unsigned fixed point decimals given precision level
dev Functions accepting uints contract derived contracts
taken fixed point decimals ( including fiat , ether , nomin quantities )
Number decimal places representation
number representing 1 0
return True iff adding x overflow
return result adding x , throwing exception case overflow
return True iff subtracting x overflow negative direction
return result subtracting x , throwing exception case overflow
return True iff multiplying x would overflow
return result multiplying x , throwing exception case overflow
return result multiplying x , interpreting operands fixed point
decimals Throws exception case overflow
dev unit factor divided product x evaluated ,
product must less 2**256
Incidentally , internal division always rounds : one could rounded nearest integer ,
one would spending significant fraction cent ( order microether
present gas prices ) order save less one part 0 5 * 10^18 per operation , operands
contain small enough fractional components would also marginally diminish
domain function defined upon
Divide UNIT remove extra factor introduced product
return True iff denominator x nonzero
return result dividing x , throwing exception divisor zero
Although 0 denominator already throws exception ,
equivalent THROW operation , consumes gas
require statement emits REVERT instead , remits remaining gas
return result dividing x , interpreting operands fixed point decimal numbers
dev Throws exception case overflow zero divisor; x must less 2^256 UNIT
Internal rounding downward : similar caveat holds safe Dec Mul ( )
Reintroduce UNIT factor divided
dev Convert unsigned integer unsigned fixed point decimal
Throw exception result would range
FILE INFORMATION
file : State sol
version : 1 1
: Dominic Romanowski
Anton Jurisevic
date :
MODULE DESCRIPTION
contract used side side external state token
contracts , Havven Nomin
provides easy way upgrade contract logic
maintaining user balances allowances designed
make changeover easy possible , since mappings
cheap straightforward migrate
first deployed contract would create state contract ,
using store balances
new contract deployed , links existing
state contract , whose owner would change associated
contract new one
= = SETTERS = =
= = MODIFIERS = =
= = EVENTS = =
FILE INFORMATION
file : Token State sol
version : 1 1
: Dominic Romanowski
Anton Jurisevic
date :
MODULE DESCRIPTION
contract holds state ERC20 compliant token
contract used side side external state token
contracts , Havven Nomin
provides easy way upgrade contract logic
maintaining user balances allowances designed
make changeover easy possible , since mappings
cheap straightforward migrate
first deployed contract would create state contract ,
using store balances
new contract deployed , links existing
state contract , whose owner would change associated
contract new one
title ERC20 Token State
notice Stores balance information ERC20 token contract
ERC20 fields
dev Constructor
param owner address controls contract
param associated Contract ERC20 contract whose state composes
= = SETTERS = =
notice Set ERC20 allowance
dev associated contract may call
param token Owner authorising party
param spender authorised party
param value total value authorised party may spend
authorising party's behalf
notice Set balance given account
dev associated contract may call
param account account whose value set
param value new balance given account
FILE INFORMATION
file : Proxy sol
version : 1 3
: Anton Jurisevic
date :
MODULE DESCRIPTION
proxy contract , recognise function
called , passes value call data
underlying target contract
proxy capacity toggle DELEGATECALL
CALL style proxy functionality
former executes proxy's context , preserve
msg sender store data proxy address latter
Therefore , contract proxy wraps CALL style must
implement Proxyable interface , order pass msg sender
underlying contract state parameter , message Sender
first 32 bytes call Data contain length ( specified abi )
Length assumed uint256 therefore maximum 32 bytes
length also leftpadded multiple 32 bytes
means moving call data across 32 bytes guarantees correctly access
data
Copy call data free memory region
Forward gas call data target contract
Revert call failed , otherwise return result
, must send message Sender explicitly
since using CALL rather DELEGATECALL
must explicitly forward ether underlying contract well
FILE INFORMATION
file : Proxyable sol
version : 1 1
: Anton Jurisevic
date :
checked : Mike Spain
approved : Samuel Brooks
MODULE DESCRIPTION
proxyable contract works hand hand Proxy contract
allow anyone interact underlying contract
directly proxy
proxy contract exists behind
caller proxy , passed contract
Note every function using member must apply Proxy
optional Proxy modifiers , otherwise invocations use stale values
FILE INFORMATION
file : Extern State Token sol
version : 1 0
: Kevin Brown
date :
MODULE DESCRIPTION
contract offers modifer prevent reentrancy
particular actions work put multiple
functions called Specifically guard
external entry points contract modifier
= = MODIFIERS = =
FILE INFORMATION
file : Extern State Token sol
version : 1 3
: Anton Jurisevic
Dominic Romanowski
date :
MODULE DESCRIPTION
partial ERC20 token contract , designed operate proxy
produce complete ERC20 token , transfer transfer
tokens must implemented , using provided Proxy internal
functions
contract utilises external state upgradeability
title ERC20 Token contract , detached state designed operate behind proxy
= = STATE VARIABLES = =
Stores balances allowances
ERC20 fields
Note decimals field defined Safe Decimal Math
dev Constructor
param proxy proxy associated contract
param name Token's ERC20 name
param symbol Token's ERC20 symbol
param total Supply total supply token
param token State Token State contract address
param owner owner contract
= = VIEWS = =
notice Returns ERC20 allowance one party spend behalf another
param owner party authorising spending funds
param spender party spending token Owner's funds
notice Returns ERC20 token balance given account
= = MUTATIVE FUNCTIONS = =
notice Set address Token State contract
dev used "pause" transfer functionality , pointing token State 0x000
balances would unreachable
Disallow transfers irretrievable addresses
Insufficient balance handled safe subtraction
we're transferring contract implements havven Token Fallback function , call
ERC223 compliant :
1 revert contract implement havven Token Fallback
many DEXes contracts expect work standard
approve transfer workflow implement token Fallback still process tokens
usual , feels harsh likely cause trouble add restriction
previously gone live vanilla ERC20
2 pass bytes parameter
solidity bug : https : github ethereum solidity issues 2884
3 also let user use custom token Fallback figure we're already standards
compliant , use case users can't implement specific function
we've called function havven Token Fallback clear following standard
dev Perform ERC20 token transfer Designed called transfer functions possessing
Proxy optional Proxy modifiers
dev Perform ERC20 token transfer Designed called transfer functions
possessing optional Proxy optional Proxy modifiers
Insufficient allowance handled safe subtraction
notice Approves spender transfer message sender's behalf
= = EVENTS = =
FILE INFORMATION
file : Fee Token sol
version : 1 3
: Anton Jurisevic
Dominic Romanowski
Kevin Brown
date :
MODULE DESCRIPTION
token also configurable fee rate
charged transfers designed overridden
order produce ERC20 compliant token
fees accrue pool , nominated authority
may withdraw
contract utilises external state upgradeability
title ERC20 Token contract , detached state
Additionally charges fees transfer
= = STATE VARIABLES = =
ERC20 members declared Extern State Token
percentage fee charged transfer
Fee may exceed 10%
address authority distribute fees
address fees pooled
= = CONSTRUCTOR = =
dev Constructor
param proxy proxy associated contract
param name Token's ERC20 name
param symbol Token's ERC20 symbol
param total Supply total supply token
param transfer Fee Rate fee rate charge transfers
param fee Authority address authority withdraw fees accumulated pool
param owner owner contract
Constructed transfer fee rate respect maximum fee rate
= = SETTERS = =
notice Set transfer fee , anywhere within range 0 10%
dev fee rate decimal format , UNIT value 100%
notice Set address user contract responsible collecting
distributing fees
= = VIEWS = =
notice Calculate Fee charged top value sent
return Return fee charged
Transfers less reciprocal transfer Fee Rate completely eaten fees
basis transfers less value result nil fee
Probably insignificant worry , following code achieve
( fee == 0 && transfer Fee Rate ! = 0 ) {
return value;
return fee;
notice value would need send recipient receives
specified value
notice amount recipient receive send certain number tokens
notice Collected fees sit distributed
dev balance nomin contract fee pool
= = MUTATIVE FUNCTIONS = =
notice Base transfer functions
Disallow transfers irretrievable addresses
Insufficient balance handled safe subtraction
Emit events transfer fee
notice ERC20 friendly transfer function
notice ERC20 friendly transfer function
fee deducted amount sent
Reduce allowance amount we're transferring
safe Sub call handle insufficient allowance
notice Ability transfer sender pays fees ( ERC20 )
fee added amount sent
notice Ability transfer sender pays fees ( ERC20 )
fee added amount sent
Reduce allowance amount we're transferring
notice Withdraw tokens fee pool given account
dev fee authority may call
0 value withdrawals nothing
Safe subtraction ensures exception thrown balance insufficient
notice Donate tokens sender's balance fee pool
Empty donations disallowed
safe Sub ensures donor sufficient balance
= = MODIFIERS = =
= = EVENTS = =
FILE INFORMATION
file : Nomin sol
version : 1 2
: Anton Jurisevic
Mike Spain
Dominic Romanowski
Kevin Brown
date :
MODULE DESCRIPTION
Havven backed nomin stablecoin contract
contract issues nomins , tokens worth 1 USD
Nomins issuable Havven holders lock
value havvens issue H * Cmax nomins Cmax
value less 1
configurable fee charged nomin transfers deposited
common pot , havven holders may withdraw
per fee period
= = STATE VARIABLES = =
= = CONSTRUCTOR = =
= = SETTERS = =
= = MUTATIVE FUNCTIONS = =
Override ERC20 transfer function order check
whether recipient account frozen Note
need check whether sender frozen account ,
since funds already confiscated ,
new funds transferred
Override ERC20 transfer function order check
whether recipient account frozen
owner may allow previously frozen contract
accept transfer nomins
Allow havven issue certain number
nomins account
Allow havven burn certain number
nomins account
= = MODIFIERS = =
= = EVENTS = =
FILE INFORMATION
file : Limited Setup sol
version : 1 1
: Anton Jurisevic
date :
MODULE DESCRIPTION
contract limited setup period function modified
setup modifier cease work
conclusion configurable length post construction setup period
title function decorated modifier contract provides
deactivates specified setup period
dev Limited Setup Constructor
param setup Duration time setup period last
FILE INFORMATION
file : Havven Escrow sol
version : 1 1
: Anton Jurisevic
Dominic Romanowski
Mike Spain
date :
MODULE DESCRIPTION
contract allows foundation apply unique vesting
schedules havven funds sold various discounts token
sale Havven Escrow gives users ability inspect
vested funds , quantities vesting dates , withdraw
fees accrue funds
fees handled withdrawing entire fee allocation
havvens inside escrow contract , allowing
contract subdivide pool proportionally within
Every time fee period rolls main Havven
contract , Havven Escrow fee pool remitted back
main fee pool redistributed next fee period
title contract hold escrowed havvens free given schedules
corresponding Havven contract
Lists ( timestamp , quantity ) pairs per account , sorted ascending time order
times given quantity havvens vests
account's total vested havven balance save recomputing fee extraction purposes
total remaining vested balance , verifying actual havven balance contract
Limit vesting entries disallow unbounded iteration vesting schedules
= = CONSTRUCTOR = =
= = SETTERS = =
= = VIEW FUNCTIONS = =
notice simple alias total Vested Account Balance : provides ERC20 balance integration
notice number vesting dates account's schedule
notice Get particular schedule entry account
return pair uints : ( timestamp , havven quantity )
notice Get time given schedule entry vest
notice Get quantity havvens associated given schedule entry
notice Obtain index next schedule entry vest given user
notice Obtain next schedule entry vest given user
return pair uints : ( timestamp , havven quantity )
notice Obtain time next schedule entry vest given user
notice Obtain quantity next schedule entry vest given user
= = MUTATIVE FUNCTIONS = =
notice Withdraws quantity havvens back havven contract
dev may called owner contract's setup period
notice Destroy vesting information associated account
notice Add new vesting entry given time quantity account's schedule
dev call accompanied either enough balance already available
contract , corresponding call havven endow ( ) , ensure
funds withdrawn , enough balance , well correctly calculating
fees
may called owner contract's setup period
Note; although function could technically used produce unbounded
arrays , foundation's command add lists
param account account append new vesting entry
param time absolute unix timestamp vested quantity may withdrawn
param quantity quantity havvens vest
empty already passed vesting entries allowed
must enough balance contract provide vesting entry
Disallow arbitrarily long vesting schedules light gas limit
Disallow adding new vested havvens earlier last one
Since entries appended , means vesting date repeated
notice Construct vesting schedule release quantities havvens
series intervals
dev Assumes quantities nonzero
sequence timestamps strictly increasing
may called owner contract's setup period
notice Allow user withdraw havvens schedule vested
list sorted; reach first future time , bail
= = EVENTS = =
FILE INFORMATION
file : Havven sol
version : 1 2
: Anton Jurisevic
Dominic Romanowski
date :
MODULE DESCRIPTION
Havven token contract Havvens transferable ERC20 tokens ,
also give holders following privileges
owner havvens may participate nomin confiscation votes ,
may also right issue nomins discretion
foundation version contract
fee period terminates , duration fees collected
period computed , next period begins Thus account may
withdraw fees owed previous period , may
per period unclaimed fees roll common pot
next period
== Average Balance Calculations ==
fee entitlement havven holder proportional average
issued nomin balance last fee period computed
measuring area graph user's issued nomin balance
time , new fee period begins , dividing
duration fee period
need update values balances account modified
occurs issuing burning issued nomin balances ,
transferring havven balances efficiency ,
adds implicit friction interacting havvens
havven holder pays recomputation whenever wants change
position , saves foundation maintain pot dedicated
resourcing
hypothetical user's balance history one fee period , pictorially :
| | p
f n
, balance times f , time transfer
occurred , updating balance p , n , present transfer occurs
new transfer occurs time n , balance p ,
must :
Add area p * ( n ) total area recorded far
Update last transfer time n
graph represents entire current fee period ,
average havvens held far ( ( f ) *s + ( n ) *p ) ( n f )
complementary computations must performed sender
recipient
Note transfer keeps global supply havvens invariant
sum balances constant , unmodified transfer
sum balances multiplied duration fee period also
constant , equivalent sum area every user's
time balance graph Dividing duration yields back total
havven supply , end fee period , really yield user's
average share havven supply period
slight wrinkle introduced consider time r fee period
rolls previous fee period k 1 r , current fee
period k afterwards last transfer took place r ,
latest transfer occurred afterwards :
k 1 | k
| | | p
f | n
r
situation area ( r f ) *s contributes fee period k 1 ,
area ( r ) *s contributes fee period k implicitly consider
zero value transfer occurred time r fee entitlement
previous period finalised time first transfer
current fee period , query withdraw fee entitlement
implementation , duration different fee periods may slightly irregular ,
check rolled occurs state changing havven
operations performed
== Issuance Burning ==
version havven contract , nomins issued
nominated havven foundation Nomins assumed
valued $1 , stable unit account
nomins issued require proportional value havvens locked ,
proportion governed current issuance ratio
means every $1 Havvens locked , $ ( issuance Ratio ) nomins issued
e issue 100 nomins , 100 issuance Ratio dollars havvens need locked
determine value amount havvens ( H ) , oracle used push
price havvens ( P H ) dollars contract value H
would : H * P H
havvens locked issuance process cannot transferred
amount locked floats based price havvens price
havvens moves , less havvens locked , issued ,
transferred freely price havvens moves , havvens locked ,
even going initial wallet balance
title Havven ERC20 contract
notice Havven contracts facilitate transfers track balances ,
also computes quantity fees havven holder entitled
= = STATE VARIABLES = =
struct handing values associated average balance calculations
Sums balances*duration current fee period
range : decimals; units : havven seconds
last period's average balance
last time data calculated
Issued nomin balances individual fee entitlements
total number issued nomins determining fee entitlements
time current fee period began
time last fee period began
Fee periods roll shorter time
fee period cannot actually roll fee relevant
operation withdrawal fee period duration update occurs ,
target , actual duration may slightly longer
must target 1 day six months
quantity nomins fee pot time
last fee rollover , fee Period Start Time
Whether user withdrawn last fees
address oracle pushes havven price contract
price havvens written UNIT
time havven price last updated
long contract assume price havvens correct
quantity nomins greater ratio
may issued given value havvens
nomins may issued value havvens backing
Whether address issue nomins
number currently outstanding nomins user issued
= = CONSTRUCTOR = =
dev Constructor
param token State pre populated contract containing token balances
provided address 0x0 , fresh one constructed contract owning tokens
param owner owner contract
= = SETTERS = =
notice Set associated Nomin contract collect fees
dev contract owner may call
notice Set associated havven escrow contract
dev contract owner may call
notice Set targeted fee period duration
dev callable contract owner duration must fall within
acceptable bounds ( 1 day 26 weeks ) Upon resetting fee period
may roll target duration shortened sufficiently
notice Set Oracle pushes havven price contract
notice Set stale period updated havven price
dev max minimum , changing wont influence anything issuance foundation
notice Set issuance Ratio issuance calculations
dev callable contract owner
notice Set whether specified issue nomins
= = VIEWS = =
= = MUTATIVE FUNCTIONS = =
notice ERC20 transfer function
Perform transfer : problem ,
exception thrown call
notice ERC20 transfer function
Perform transfer : problem ,
exception thrown call
notice Compute last period's fee entitlement message sender
deposit nomin account
deposit fees frozen accounts
Check period rolled first
allow accounts withdraw fees per period
Sender receives share last period's collected fees proportional
average fraction last period's issued nomins
notice Update havven balance averages since last transfer
entitlement adjustment
dev Since updates last transfer timestamp , invoked
consecutively , function nothing first call
Also , adjust total issuance time
update total balances first
notice Compute new Issuance Data old balance
balance last updated previous fee period , average
balance period pre transfer balance
balance last updated previous fee period
overflow zero denominator problems , since last Fee Period Start Time fee Period Start Time last Modified
implies quantities strictly positive
Roll next fee period
balance last updated current fee period
notice Recompute return given account's last average balance
notice Issue nomins sender's havvens
dev Issuance allowed havven price stale sender issuer
need check price stale , checked issuable Nomins
notice Burn nomins clear issued nomins free havvens
matter price stale user issuer , non issuers issued nomins
nomin burn safe Sub balance ( revert enough nomins )
safe sub ensures amount = number issued
notice Check fee period rolled , set new fee period start
time , record fees collected nomin contract
fee period rolled
= = Issuance Burning = =
notice maximum nomins issuer issue total havven quantity ignores
already issued nomins
notice remaining nomins issuer issue total havven quantity
notice total havvens owned account , escrowed unescrowed ,
nomins issued
includes already used collateral ( locked ) ,
available issuance ( unlocked )
notice collateral would locked issuance , exceed account's actual collateral
notice Collateral locked due issuance , cannot
transferred addresses capped account's total collateral
notice Collateral locked available issuance
notice number havvens free transferred account
dev enough available Havvens , could
havvens escrowed , however transfer would
fail means escrowed havvens locked first ,
actual transferable ones
notice value USD given amount HAV
notice value HAV given amount USD
notice Access point oracle update price havvens
callable oracle
Must recently sent price , far future
( can't lock updating oracle longer )
Check fee period rollover within price pushed every 15min
notice Check price havvens updated longer stale period
= = MODIFIERS = =
= = EVENTS = =
FILE INFORMATION
file : Issuance Controller sol
version : 2 0
: Kevin Brown
date :
MODULE DESCRIPTION
Issuance controller contract issuance controller provides
way users acquire nomins ( Nomin sol ) havvens
( Havven sol ) paying ETH way users acquire havvens
( Havven sol ) paying nomins Users also deposit nomins
allow users purchase ETH ETH sent
user offered nomins sale
smart contract contains balance currency ,
allows owner contract ( Havven Foundation )
manage available balance havven discretion ,
users allowed deposit withdraw nomin deposits
yet taken another user
title Issuance Controller Contract
= = STATE VARIABLES = =
address oracle pushes USD price havvens ether contract
allow oracle submit times forward future
constant
long contract assume price asset correct
time prices last updated
USD price havvens denominated UNIT
USD price ETH denominated UNIT
= = CONSTRUCTOR = =
dev Constructor
param owner owner contract
param funds Wallet recipient ETH Nomins sent contract exchanging
param havven Havven contract we'll interact balances sending
param nomin Nomin contract we'll interact balances sending
param oracle address able update price information
param usd Eth Price current price ETH USD , expressed UNIT
param usd Hav Price current price Havven USD , expressed UNIT
Owned initialised Self Destructible
= = SETTERS = =
notice Set funds wallet ETH raised held
param funds Wallet new address forward ETH Nomins
notice Set Oracle pushes havven price contract
param oracle new oracle address
notice Set Nomin contract issuance controller uses issue Nomins
param nomin new nomin contract target
notice Set Havven contract issuance controller uses issue Havvens
param havven new havven contract target
notice Set stale period updated price variables
param time new price Stale Period
= = MUTATIVE FUNCTIONS = =
notice Access point oracle update prices havvens eth
param new Eth Price current price ether USD , specified 18 decimal places
param new Havven Price current price havvens USD , specified 18 decimal places
param time Sent timestamp oracle transaction created ensures consider stale prices current times heavy network congestion
Must recently sent price , far future
( can't lock updating oracle longer )
notice Fallback function ( exchanges ETH n USD )
notice Exchange ETH n USD
notice Exchange ETH n USD insisting particular rate allows user
exchange protecting frontrunning contract owner exchange rate
param guaranteed Rate exchange rate ( ether price ) must honored call revert
notice Exchange ETH HAV
notice Exchange ETH HAV insisting particular set rates allows user
exchange protecting frontrunning contract owner exchange rates
param guaranteed Ether Rate ether exchange rate must honored call revert
param guaranteed Havven Rate havven exchange rate must honored call revert
notice Exchange n USD Havvens
param nomin Amount amount nomins user wishes exchange
notice Exchange n USD Havvens insisting particular rate allows user
exchange protecting frontrunning contract owner exchange rate
param nomin Amount amount nomins user wishes exchange
param guaranteed Rate rate ( havven price ) caller wishes insist upon
notice Allows owner withdraw havvens contract needed
param amount amount havvens attempt withdraw ( 18 decimal places )
notice Withdraw nomins : Allows owner withdraw nomins contract needed
param amount amount nomins attempt withdraw ( 18 decimal places )
= = VIEWS = =
notice Check prices updated longer stale period
notice Calculate many havvens receive transfer
amount nomins
param amount amount nomins ( 18 decimal places ) want ask
notice Calculate many havvens receive transfer
amount ether
param amount amount ether ( wei ) want ask
notice Calculate many nomins receive transfer
amount ether
param amount amount ether ( wei ) want ask
= = MODIFIERS = =
= = EVENTS = =
Paused false , last Pause Time 0 upon initialisation
Ensure we're actually changing state anything
Set paused state
applicable , set last pause time
Let everyone know pause state changed
address contract modify variables
changed owner contract
Change associated contract new address
contract treated like abstract contract
github ethereum solidity issues 2884
address contract ? check code size address know
solium disable next line security inline assembly
Retrieve size code recipient address
there's code , contract
need optionally call havven Token Fallback ( address , uint value )
can't call normal way reverts recipient implement function
We'll use call ( ) , means need function selector We've pre computed
abi encode Signature ( "havven Token Fallback ( address , uint256 ) " ) , save gas
solium disable next line security low level calls
yes , specifically care call fails , we're checking return value
Emit standard ERC20 transfer event
Accounts lost privilege transact nomins
Nomin transfers incur 15 bp fee default
havven contract fee authority
possible transfer fee pool directly ( confiscate balance )
havven set fee Authority calling depending
havven's internal logic
valid general skip currently issued nomins
release , issuers nonzero issuance Data current issuance
case issuance Draft exceeds collateral , nothing free
case draft exceeds escrow , whole collateral
return fraction balance remains free
case draft exceed escrow , return entire balance
Address ether raised transfered
Ownable
Funds Wallet
contracts needed
Oracle values Allows price updates
Returns number Nomins ( n USD ) received
multiplication works usd Eth Price specified
18 decimal places , like currency base
Store ETH funds wallet
Send nomins
Note : Fees calculated Nomin contract ,
request specific transfer , fee
automatically deducted sent fee pool
Returns number Nomins ( n USD ) received
Returns number Havvens ( HAV ) received
many Havvens going receiving ?
Store ETH funds wallet
send Havvens
Returns number Havvens ( HAV ) received
Returns number Havvens ( HAV ) received
many Havvens going receiving ?
Ok , transfer Nomins address
send Havvens
Returns number Havvens ( HAV ) received
emit events assume anyone
wants watch Issuance Controller
watch ERC20 events Nomin Havven contracts
filtered address
emit events assume anyone
wants watch Issuance Controller
watch ERC20 events Nomin Havven contracts
filtered address
many nomins would receive transfer fee ?
would worth havvens based current price ?
much ETH sent us worth n USD ( ignoring transfer fee ) ?
, many HAV USD amount buy ?
many nomins would amount ether worth ?
many would receive transfer ( deducting transfer fee )

title ERC20Basic
dev Simpler version ERC20 interface
dev see https : github ethereum EIPs issues 179
title ERC20 interface
dev see https : github ethereum EIPs issues 20
title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
title Safe ERC20
dev Wrappers around ERC20 operations throw failure
use library add `using Safe ERC20 ERC20;` statement contract ,
allows call safe operations `token safe Transfer ( ) ` , etc
title Ownable
dev Ownable contract owner address , provides basic authorization control
functions , simplifies implementation "user permissions"
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner relinquish control contract
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
dev Transfers control contract new Owner
param new Owner address transfer ownership
title Contracts able recover tokens
Syl Ti
dev allow contract recover ERC20 token received contract transferring balance contract owner
prevent accidental loss tokens
dev Reclaim ERC20Basic compatible tokens
param token ERC20Basic address token contract
File : openzeppelin solidity contracts token ERC20 ERC20Basic sol
github ethereum EIPs issues 179
File : openzeppelin solidity contracts token ERC20 ERC20 sol
github ethereum EIPs issues 20
File : contracts interface IBasic Multi Token sol
File : contracts interface IMulti Token sol
File : openzeppelin solidity contracts math Safe Math sol
Gas optimization : cheaper asserting 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
assert ( b 0 ) ; Solidity automatically throws dividing 0
uint256 c = b;
assert ( == b * c + % b ) ; case hold
File : openzeppelin solidity contracts token ERC20 Safe ERC20 sol
File : openzeppelin solidity contracts ownership Ownable sol
File : openzeppelin solidity contracts ownership Reclaim Token sol
File : contracts registry Multi Buyer sol
including 0 LENGTH values
optimization total Supply

title Safe Math
dev Math operations safety checks throw error
dev Multiplies two numbers , throws overflow
dev Integer division two numbers , truncating quotient
dev Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
dev Adds two numbers , throws overflow
Contract handle behavior related ownership contracts
handles tracking current owner transferring ownership new owners
Interface ERC223 compliant
ERC223 industry standard smart contracts
Contract working ERC223 tokens receiver contract transfers
tkn variable analogue msg variable Ether transaction
tkn sender person initiated token transaction ( analogue msg sender )
tkn value number tokens sent ( analogue msg value )
tkn data data token transaction ( analogue msg data )
tkn sig 4 bytes signature function
data token transaction function execution
Nicholas Tuley
desc Contract C2L token carries token specific behaviors C2L token
return total supply coin
get balance given user
param token Owner address user account queried
return balance given account
Check given address contract
owner mints new coins
param amount number coins mint
condition
sender message must owner minter creator contract
transfer tokens user msg sender
param address user coins sent
param value number coins send
param data msg data transfer
param custom fallback custom fallback function transfer
conditions :
coin sender must enough coins carry transfer
balances sender receiver tokens must edited another transfer time
return True execution transfer successful , False otherwise
Carry transfer tokens accounts
param address user coins sent
param value number coins send
param data msg data transfer
conditions :
coin sender must enough coins carry transfer
balances sender receiver tokens must edited another transfer time
return True execution transfer successful , False otherwise
Backwards compatible transfer function satisfy ERC20
update address LUT list addresses checking address list already , , add address list
param lookup address check list
assert ( b 0 ) ; Solidity automatically throws dividing 0
assert ( == b * c + % b ) ; case hold
reset new Owner 0 null
constants
starting balance 21 million coins
variables
name currency
mapping prevent multiple edits account occuring time ( reentrancy )
number coin active existence
balances users coin
map holding much user allowed transfer addresses
C2L contract constructor
getter methods basic contract info
toggle Edited status account
retrieve size code target address , needs assembly
make sure sender enough coins transfer
transfer coins
log transfer
standard function transfer similar ERC20 transfer data
added due backwards compatibility reasons
transfer function called transaction target address
transfer function called transaction target contract
default , fallback function
self destruct function contract

: dm & w
ATTENTION ! new amount wei
Use https : etherconverter online
