source : https : smartcontractsecurity github SWC registry docs SWC 124 arbitrary location write simplesol
vulnerable lines : 27
smartcontractsecurity github SWC registry docs SWC 124 arbitrary location write simplesol
yes report ACCESS CONTROL
condition always true since array lengths unsigned
underflow caused
write index less bonus Codes length

source : https : smartcontractsecurity github SWC registry docs SWC 105 wallet 02 refund nosubsol
vulnerable lines : 36
User add pay withdraw Ether
Unfortunately developer forgot set user's balance 0 refund ( ) called
attacker pay small amount Ether call refund ( ) repeatedly empty contract
smartcontractsecurity github SWC registry docs SWC 105 wallet 02 refund nosubsol
yes report ACCESS CONTROL
emergency owner migrate allfunds different address

source : https : smartcontractsecurity github SWC registry docs SWC 105 wallet 03 wrong constructorsol
vulnerable lines : 19 , 20
User add pay withdraw Ether
constructor wrongly named , anyone become 'creator' withdraw funds
smartcontractsecurity github SWC registry docs SWC 105 wallet 03 wrong constructorsol
yes report ACCESS CONTROL
emergency owner migrate allfunds different address

source : https : smartcontractsecurity github SWC registry docs SWC 105 wallet 04 confused signsol
vulnerable lines : 30
User add pay withdraw Ether
Unfortunatelty , developer drunk used wrong comparison operator "withdraw ( ) "
Anybody withdraw arbitrary amounts Ether : ( )
smartcontractsecurity github SWC registry docs SWC 105 wallet 04 confused signsol
yes report ACCESS CONTROL
emergency owner migrate allfunds different address

source : https : github trailofbits smart contracts blob master wrong constructor name incorrect constructor sol
vulnerable lines : 20
github trailofbits smart contracts blob master wrong constructor name incorrect constructor sol
name constructor Missing
Anyone call Iam Missing contract deployed
yes report ACCESS CONTROL

source : https : smartcontractsecurity github SWC registry docs SWC 118 incorrect constructor name1sol
vulnerable lines : 18
smartcontractsecurity github SWC registry docs SWC 118 incorrect constructor name1sol
yes report ACCESS CONTROL

source : https : smartcontractsecurity github SWC registry docs SWC 118 incorrect constructor name2sol
vulnerable lines : 17
smartcontractsecurity github SWC registry docs SWC 118 incorrect constructor name2sol
yes report ACCESS CONTROL

source : https : smartcontractsecurity github SWC registry docs SWC 124 mapping writesol
vulnerable lines : 20
smartcontractsecurity github SWC registry docs SWC 124 mapping writesol
code derived Capture Ether https : capturetheether challenges math mapping
yes report ACCESS CONTROL

source : https : github Smart Contract Security SWC registry blob master test cases solidity unprotected critical functions multiowned vulnerable multiowned vulnerable sol
vulnerable lines : 38
title Multi Ownable
dev Ownable constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Adding new owners
Note "only Owner" modifier missing
dev Deleting owners
github Smart Contract Security SWC registry blob master test cases solidity unprotected critical functions multiowned vulnerable multiowned vulnerable sol
owner = parent owner
yes report ACCESS CONTROL

source : https : consensys github smart contract best practices recommendations avoid using txorigin
vulnerable lines : 20
Modified Gerhard Wagner
consensys github smart contract best practices recommendations avoid using txorigin
yes report ACCESS CONTROL

source : https : github sigp solidity security blog
vulnerable lines : 20
github sigp solidity security blog
collect ether
yes report ACCESS CONTROL

source : https : smartcontractsecurity github SWC registry docs SWC 112 proxysol
vulnerable lines : 19
smartcontractsecurity github SWC registry docs SWC 112 proxysol
yes report ACCESS CONTROL
Use delegatecall caution make sure never call untrusted contracts

Source Code first verified https : etherscan Friday , April 26 , 2019
etherscan Friday , April 26 , 2019
Constructor
Total supply
Get token balance account `token Owner`
Transfer balance token owner's account `to` account
Owner's account must sufficient balance transfer
0 value transfers allowed
Token owner approve `spender` transfer ( ) `tokens`
token owner's account
https : github ethereum EIPs blob master EIPS eip 20 token standard md
recommends checks approval double spend attack
implemented user interfaces
Transfer `tokens` `from` account `to` account
calling account must already sufficient tokens approve ( )
spending `from` account
account must sufficient balance transfer
Spender must sufficient allowance transfer
0 value transfers allowed
Returns amount tokens approved owner
transferred spender's account
Token owner approve `spender` transfer ( ) `tokens`
token owner's account `spender` contract function
`receive Approval ( ) ` executed
accept ETH
Owner transfer accidentally sent ERC20 tokens

Source Code first verified https : etherscan Friday , April 26 , 2019
return name token
return symbol token
return number decimals token
dev Constructor gives msg sender existing tokens
etherscan Friday , April 26 , 2019

website : https : exclusiveplatform
title Safe Math
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
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
20% bonus 5 eth
5% bonus 1 eth
exclusiveplatform
mitigates ERC20 short address attack
suggested izqui9 @ http : bit ly 2NMMCNv
@dev actual transfer function token contract ,
called functions contract
@param address holding tokens transferred
@param address recipient
@param amount amount tokens transferred
@return True transfer successful
allow transfer 0x0 token contract
@return balance ` owner`
@notice `msg sender` approves ` spender` spend ` amount` tokens
behalf modified version ERC20 approve function
little bit safer
@param spender address account able transfer tokens
@param amount amount tokens approved transfer
@return True approval successful
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

'Yesbuzz' contract
Mineable & Deflationary ERC20 Token using Proof Work
Symbol : YESBUZ
Name : Yesbuzz
Total supply : 21 , 000 , 000 00
Decimals : 8
Safe maths
return smaller two inputs ( b )
ERC Token Standard 20 Interface
https : github ethereum EIPs blob master EIPS eip 20 token standard md
Contract function receive approval execute function one call
Borrowed Mini Token
Owned contract
ERC20 Token , addition symbol , name decimals
initial fixed supply
number 'blocks' mined
little number
big number easier ; find solution smaller
uint public MAXIMUM TARGET = 2**224; bitcoin uses 224
generate new one new reward minted
Constructor
divided 1000 , 10 1000 = 0 01 = 1%
owner gets nothing ! must mine ERC20 token
balances[owner] = total Supply;
Transfer ( address ( 0 ) , owner , total Supply ) ;
Po W must contain work includes recent ethereum block hash ( challenge number ) msg sender's address prevent MITM attacks
challenge digest must match expected
digest must smaller target
allow one reward challenge
prevent answer awarding twice
Cannot mint tokens
set readonly diagnostics data
new 'block' mined
max supply era exceeded next reward round enter new era happens
40 final reward era , almost tokens minted
final era reached , tokens given assert function
set next minted supply era change
total supply 2100000000000000 8 decimal places
every often , readjust difficulty Dont readjust deploying
make latest ethereum block hash part next challenge Po W prevent pre mining future blocks
last since protection mechanism mint ( ) function
https : en bitcoin wiki Difficulty formula difficulty 3F
2017 bitcoin difficulty 17 zeroes , 8 early days
readjust target 5 percent
assume 360 ethereum blocks per hour
want miners spend 10 minutes mine 'block' , 60 ethereum blocks = one Bitcoin V epoch
60 times slower ethereum
less eth blocks passed time expected
5% blocks mined expected 5 100% blocks mined expected 100
make harder
always 0 1000
make easier
difficult
easy
recent ethereum block hash , used prevent pre mining future blocks
number zeroes digest Po W solution requires Auto adjusts
21m coins total
reward begins 50 cut half every reward era ( tokens mined )
get half way thru coins , get 25 per block
every reward era , reward amount halves
help debug mining software
help debug mining software
Total supply
Get token balance account `token Owner`
Transfer balance token owner's account `to` account
Owner's account must sufficient balance transfer
0 value transfers allowed
Token owner approve `spender` transfer ( ) `tokens`
token owner's account
https : github ethereum EIPs blob master EIPS eip 20 token standard md
recommends checks approval double spend attack
implemented user interfaces
Transfer `tokens` `from` account `to` account
calling account must already sufficient tokens approve ( )
spending `from` account
account must sufficient balance transfer
Spender must sufficient allowance transfer
0 value transfers allowed
Returns amount tokens approved owner
transferred spender's account
Token owner approve `spender` transfer ( ) `tokens`
token owner's account `spender` contract function
`receive Approval ( ) ` executed
accept ETH
Owner transfer accidentally sent ERC20 tokens

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 owned
dev owned contract owner address , provides basic authorization
control functions , simplifies implementation "user permissions"
dev owned constructor sets original `owner` contract sender
account
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
dev withdraws Contracts balance
functionhash 0x7ee20df8
team withdraw Contracts
either settled refunded funds transferred contract owner
team destruct

Source Code first verified https : etherscan Tuesday , May 7 , 2019
etherscan Tuesday , May 7 , 2019
Name , example "My test token"
Returns number decimal places used token example , set 3 , means supports 0 001 representation
Token abbreviation , like MTT
variable set TRUE function set Pause Status , transfer transactions fail
Record owner contract
Set initial total
Set initial total
Subtract token amount value message sender's account
Add token amount value receiving account
Trigger coin transfer event
Trigger coin transfer event
Increase token amount value receiving account
spending account reduces token amount value
number message sender transfer account reduced value
Trigger coin transfer event
Trigger coin transfer event
Allow spender transfer number tokens owner
following special logic token protocol
Transfer ownership protocol transfer attached tokens along
Trigger contract ownership transfer event
Paused true , pause transfer transactions
Modify contract name

title Safe Math
dev Unsigned math operations safety checks revert error
dev Multiplies two unsigned integers , reverts overflow
dev Integer division two unsigned integers truncating quotient , reverts division zero
dev Subtracts two unsigned integers , reverts overflow ( e subtrahend greater minuend )
dev Adds two unsigned integers , reverts overflow
dev Divides two unsigned integers returns remainder ( unsigned integer modulo ) ,
reverts dividing zero
Mindsync Platform contract
Constructor
First time rules setup
Initialize contract
param token Address token address
param minimum Tokens Vote address vote number tokens held address exceed number
param minimum Percent Pass AVote proposal vote sum tokens held voters exceed number divided 100 muliplied token total supply
param minutes Debate minimum amount delay proposal made executed
Change voting rules
Make proposals need discussed least `minutes Debate 60` hours
voters combined must `minimum Percent Pass AVote` multiplied total supply tokens `token Address` executed
param token Address token address
param minimum Tokens Vote address vote number tokens held address exceed number
param minimum Percent Pass AVote proposal vote sum tokens held voters exceed number divided 100 muliplied token total supply
param minutes Debate minimum amount delay proposal made executed
Add Proposal
Propose execute transaction
param destination transaction destination address
param wei Amount amount wei
param transaction Description Description transaction
param transaction Bytecode bytecode transaction
Check proposal code matches
param proposal Number ID number proposal query
param destination transaction destination address
param wei Amount amount wei
param transaction Bytecode bytecode transaction
Sign proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param sign Proposal true sign
Log vote proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param supports Proposal either favor
Finish vote
Count votes proposal `proposal Number` execute approved
param proposal Number proposal number
param transaction Bytecode optional : transaction contained bytecode , need send
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
Modifier allows tokenholders least minimum Tokens Vote tokens vote create new proposals
Modifier allows chairman execute function
past voting deadline
already executed
supplied code matches proposal
tally results
Check minimum quorum reached
Proposal passed; execute transaction
Proposal failed
Fire Events

Source Code first verified https : etherscan Saturday , April 27 , 2019
title ERC20 interface
dev see https : eips ethereum org EIPS eip 20
title Safe Math
dev Unsigned math operations safety checks revert error
dev Multiplies two unsigned integers , reverts overflow
dev Integer division two unsigned integers truncating quotient , reverts division zero
dev Subtracts two unsigned integers , reverts overflow ( e subtrahend greater minuend )
dev Adds two unsigned integers , reverts overflow
dev Divides two unsigned integers returns remainder ( unsigned integer modulo ) ,
reverts dividing zero
title Standard ERC20 token
dev Implementation basic standard token
https : eips ethereum org EIPS eip 20
Originally based code First Blood :
https : github Firstbloodio token blob master smart contract First Blood Token sol
implementation emits additional Approval events , allowing applications reconstruct allowance status
accounts listening said events Note required specification ,
compliant implementations may
dev Total number tokens existence
dev Gets balance specified address
param owner address query balance
return uint256 representing amount owned passed address
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 Transfer token specified address
param address transfer
param value amount 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 Transfer tokens one address another
Note function emits Approval event , required per specification ,
compliant implementations may emit event
param address address want send tokens
param address address want transfer
param value uint256 amount tokens transferred
dev Increase amount tokens owner allowed spender
approve called allowed[msg sender][spender] == 0 increment
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
Emits Approval event
param spender address spend funds
param added Value amount tokens increase allowance
dev Decrease amount tokens owner allowed spender
approve called allowed[msg sender][spender] == 0 decrement
allowed value better use function avoid 2 calls ( wait
first transaction mined )
Monolith DAO Token sol
Emits Approval event
param spender address spend funds
param subtracted Value amount tokens decrease allowance
dev Transfer token specified addresses
param address transfer
param address transfer
param value amount transferred
dev Internal function mints amount token assigns
account encapsulates modification balances
proper events emitted
param account account receive created tokens
param value amount created
dev Internal function burns amount token given
account
param account account whose tokens burnt
param value amount burnt
dev Approve address spend another addresses' tokens
param owner address owns tokens
param spender address spend tokens
param value number tokens spent
dev Internal function burns amount token given
account , deducting sender's allowance said account Uses
internal burn function
Emits Approval event ( reflecting reduced allowance )
param account account whose tokens burnt
param value amount burnt
title Burnable Token
dev Token irreversibly burned ( destroyed )
dev Burns specific amount tokens
param value amount token burned
dev Burns specific amount tokens target address decrements allowance
param address account whose tokens burned
param value uint256 amount token burned
title ERC20Detailed token
dev decimals visualization purposes
operations done using smallest indivisible token unit ,
Ethereum operations done wei
return name token
return symbol token
return number decimals token
etherscan Saturday , April 27 , 2019
File : contracts token ERC20 IERC20 sol
eips ethereum org EIPS eip 20
File : contracts math Safe Math sol
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
File : contracts token ERC20 ERC20 sol
eips ethereum org EIPS eip 20
github Firstbloodio token blob master smart contract First Blood Token sol
github ethereum EIPs issues 20 issuecomment 263524729
File : contracts token ERC20 ERC20Burnable sol
File : contracts token ERC20 ERC20Detailed sol
File : contracts token AGR sol

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 Returns addition two unsigned integers , reverting
overflow
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
dev Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
dev Returns subtraction two unsigned integers , reverting custom message
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
NOTE : feature next version Open Zeppelin Contracts
dev Get via `npm install @openzeppelin contracts@next`
dev Returns multiplication two unsigned integers , reverting
overflow
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
dev Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns integer division two unsigned integers Reverts custom message
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
NOTE : feature next version Open Zeppelin Contracts
dev Get via `npm install @openzeppelin contracts@next`
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts custom message dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
NOTE : feature next version Open Zeppelin Contracts
dev Get via `npm install @openzeppelin contracts@next`
MATH
DATA
FUNCTIONALITY
dev sets 0 initials tokens , owner , supply Controller
serves constructor proxy compiles
memory model Implementation contract
constructor used ensure implementation
contract initialized uncontrolled implementation
contract might lead misleading state
users accidentally interact
dev Throws called account owner
dev Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
File : contracts zeppelin Safe Math sol
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin contracts pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
File : contracts App sol
INITIALIZATION DATA
OWNER DATA
INITIALIZATION FUNCTIONALITY
OWNER FUNCTIONALITY

* whitebetting whitest football betting game based ethereum blockchain
Game information
game start time
game odds
Checking game status
Checking whether winning paid
Player betting infomation
betting type
Events issued make statistic recovery easier
Constructor
Change game status
Refresh game odd
Save game information
Player make bet
Minium amount bet 0 001 ether
Check whether odds valid
Compare match mainnet odds submitted odds betting type
Betting possible game opening
Betting possible 10 min ago
Save betting information
Give prize money game result
Check game status whether opening
Check ever compensated
Check player betted
Give prize money !
Change game status
paid
Standard modifier methods invokable contract owner
Get balance CA
Deposit owner CA
Change Owner
Fallback function
Withdraw CA owner

Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold

fee whitelist
transfer amount zero
emit event stop execution
Calculate receiver balance
initial receive full value
Change sender balance
transaction whitelisted
calculate fees
Subtract fees receiver amount
Burn tokens
Transfer balance Dan Pan
Sanity checks
tokens created
Add tokens receiver
transfer amount zero
emit event stop execution
Calculate receiver balance
initial receive full value
Change sender balance
transaction whitelisted
calculate fees
Subtract fees receiver amount
Burn tokens
Transfer balance Dan Pan
Sanity checks
tokens created
Add tokens receiver

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 Returns addition two unsigned integers , reverting
overflow
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
dev Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
dev Returns multiplication two unsigned integers , reverting
overflow
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
dev Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
* Gods Unchained Raffle Token Exchange
* Version 1 0
* dedicated contract listing ( selling ) buying raffle tokens
* https : gu cards
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
V R B L E
raffle token contract
case exchange paused
Standard contract ownership
Next id next listing
raffle token listings mapped id
purchases
Next id next purche
R U C
listing raffle tokens
price per token ( wei )
many tokens ? ( Original Amount )
many tokens left ? ( Maybe altered due partial sales )
Listed ?
Active Inactive listing ?
purchase raffle tokens
many tokens ?
total price payed
purchase happen ?
EVENTS
F E R
Invokable contract owner
Invokable exchange paused
C N R U C R
F U N C N
buy Raffle
Add listing
Cancel listing
Set paused
Funds withdrawal cover operational costs
Contract may destroyed nothing else going
funds transferred contract owner

Source Code first verified https : etherscan Tuesday , May 7 , 2019
etherscan Tuesday , May 7 , 2019
name , instance , "My test token"
Returns number decimals token uses set 3 , example , would support representation 0 001
Abbreviation token , like MTT
function sets Pause Status true , transfer transactions fail
Recording contract's owner
Set starting total
Set starting total
Subtract value number tokens account message sender
Transfer value number tokens recipient's account
Trigger coin transfer event
Trigger coin transfer event
Add value number tokens recipient's account
Deduct value number tokens payer's account ,
message sender reduce amount value transferred account
Trigger coin transfer event
Trigger coin transfer event
Allow spender take certain number tokens owner
following specific logic token protocol
Transfer ownership contract also hand tokens attached
Trigger contract ownership transfer event
Paused true , transactions paused
Amend contract name

Source Code first verified https : etherscan Thursday , May 9 , 2019
title Safe Math
dev Unsigned math operations safety checks revert error
dev Subtracts two unsigned integers , reverts overflow ( e subtrahend greater minuend )
dev Adds two unsigned integers , reverts overflow
Token contract interface external use
title Token definition
dev Define token paramters including ERC20 ones
dev Get balance specified address
param owner address query
dev transfer token specified address
param address transfer
param value amount transferred
dev transfer token address another specified address using allowance
param address token comes
param address transfer
param value amount transferred
dev Assign allowance specified address use owner balance
param spender address allowed spend
param value amount allowed
dev Get allowance specified address use another address balance
param owner address owner tokens
param spender address allowed spender
dev Log Events
title Asset
dev Initial supply creation
dev Function handle callback calls
etherscan Thursday , May 9 , 2019
mapping balances per address
mapping allowances
initial token creation

dev Returns addition two unsigned integers , reverting
overflow
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
dev Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
dev Returns multiplication two unsigned integers , reverting
overflow
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
dev Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns name token
dev Returns symbol token , usually shorter version
name
dev Returns number decimals used get user representation
example , `decimals` equals `2` , balance `505` tokens
displayed user `5 , 05` ( `505 10 ** 2` )
Tokens usually opt value 18 , imitating relationship
Ether Wei
Note information used display purposes :
way affects arithmetic contract , including
`IERC20 balance Of` `IERC20 transfer`
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 Creates `amount` tokens assigns `account` , increasing
total supply
Emits `Transfer` event `from` set zero address
Requirements
`to` cannot zero address
dev See `IERC20 total Supply`
dev See `IERC20 balance Of`
dev See `IERC20 transfer`
Requirements :
`recipient` cannot zero address
caller must balance least `amount`
dev See `IERC20 allowance`
dev See `IERC20 approve`
Requirements :
`spender` cannot zero address
dev See `IERC20 transfer From`
Emits `Approval` event indicating updated allowance
required EIP See note beginning `ERC20`;
Requirements :
`sender` `recipient` cannot zero address
`sender` must balance least `value`
caller must allowance `sender`'s tokens least
`amount`
dev Atomically increases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
dev Atomically decreases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
`spender` must allowance caller least
`subtracted Value`
dev Moves tokens `amount` `sender` `recipient`
internal function equivalent `transfer` , used
e g implement automatic token fees , slashing mechanisms , etc
Emits `Transfer` event
Requirements :
`sender` cannot zero address
`recipient` cannot zero address
`sender` must balance least `amount`
dev Destoys `amount` tokens `account` , reducing
total supply
Emits `Transfer` event `to` set zero address
Requirements
`account` cannot zero address
`account` must least `amount` tokens
dev Sets `amount` allowance `spender` `owner`s tokens
internal function equivalent `approve` , used
e g set automatic allowances certain subsystems , etc
Emits `Approval` event
Requirements :
`owner` cannot zero address
`spender` cannot zero address
dev Destoys `amount` tokens `account` `amount` deducted
caller's allowance
See ` burn` ` approve`
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
Divisible 1 100 ( 0 1 % )

Copyright ( c ) 2019 Onwards Bitpayer Inc ( https : dex bitpayer )
Contract designed Ether Authority ( https : Ether Authority )
Safe Math Library
library Safe Math {
dev Returns addition two unsigned integers , reverting
overflow
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
dev Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
dev Returns multiplication two unsigned integers , reverting
overflow
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
dev Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dex bitpayer )
Ether Authority )
Safe Math Library
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
Contract Manage Ownership
flow prevent transferring ownership wrong wallet mistake
hault non owner functions case imergency default false
account receive fees
mapping token addresses mapping account balances ( token=0 means Ether )
mapping user accounts mapping order hashes booleans ( true = submitted user , equivalent offchain signature )
mapping user accounts mapping order hashes uints ( amount order filled )
Calculate percent return result
contract without fallback automatically reject incoming ether
function ( ) external { }
require ( trading Fee = trading Fee ) ;
holds ether fee
remember call Token ( address ) approve ( , amount ) contract able transfer behalf
amount amount Get terms

title Safe Math
dev Unsigned math operations safety checks revert error
dev Multiplies two unsigned integers , reverts overflow
dev Integer division two unsigned integers truncating quotient , reverts division zero
dev Subtracts two unsigned integers , reverts overflow ( e subtrahend greater minuend )
dev Adds two unsigned integers , reverts overflow
dev Divides two unsigned integers returns remainder ( unsigned integer modulo ) ,
reverts dividing zero
Mindsync Platform contract
Constructor
First time rules setup
Initialize contract
param token Address token address
param minimum Tokens Vote address vote number tokens held address exceed number
param minimum Percent Pass AVote proposal vote sum tokens held voters exceed number divided 100 muliplied token total supply
param minutes Debate minimum amount delay proposal made executed
Change voting rules
Make proposals need discussed least `minutes Debate 60` hours
voters combined must `minimum Percent Pass AVote` multiplied total supply tokens `token Address` executed
param token Address token address
param minimum Tokens Vote address vote number tokens held address exceed number
param minimum Percent Pass AVote proposal vote sum tokens held voters exceed number divided 100 muliplied token total supply
param minutes Debate minimum amount delay proposal made executed
Add Proposal
Propose execute transaction
param destination transaction destination address
param wei Amount amount wei
param transaction Description Description transaction
param transaction Bytecode bytecode transaction
Check proposal code matches
param proposal Number ID number proposal query
param destination transaction destination address
param wei Amount amount wei
param transaction Bytecode bytecode transaction
Sign proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param sign Proposal true sign
Log vote proposal
Vote `supports Proposal ? support : against` proposal `proposal Number`
param proposal Number number proposal
param supports Proposal either favor
Finish vote
Count votes proposal `proposal Number` execute approved
param proposal Number proposal number
param transaction Bytecode optional : transaction contained bytecode , need send
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
Modifier allows tokenholders least minimum Tokens Vote tokens vote create new proposals
Modifier allows chairman execute function
past voting deadline
already executed
supplied code matches proposal
tally results
Check minimum quorum reached
Proposal passed; execute transaction
Proposal failed
Fire Events

Source Code first verified https : etherscan Thursday , March 28 , 2019
etherscan Thursday , March 28 , 2019
'August Coin' token contract
Deployed : 0xe4948b8A5609c3c39E49e C1e36679a94F72D62b
Symbol : AUC
Name : August Coin
Total supply : 100000000
Decimals : 18
Enjoy
( c ) Ahiwe Onyebuchi Valentine
Safe maths
ERC Token Standard 20 Interface
https : github ethereum EIPs blob master EIPS eip 20 token standard md
Contract function receive approval execute function one call
Borrowed Mini Token
Owned contract
ERC20 Token , addition symbol , name decimals assisted
token transfers
Constructor
Total supply
Get token balance account token Owner
Transfer balance token owner's account account
Owner's account must sufficient balance transfer
0 value transfers allowed
Token owner approve spender transfer ( ) tokens
token owner's account
https : github ethereum EIPs blob master EIPS eip 20 token standard md
recommends checks approval double spend attack
implemented user interfaces
Transfer tokens account account
calling account must already sufficient tokens approve ( )
spending account
account must sufficient balance transfer
Spender must sufficient allowance transfer
0 value transfers allowed
Returns amount tokens approved owner
transferred spender's account
Token owner approve spender transfer ( ) tokens
token owner's account spender contract function
receive Approval ( ) executed
accept ETH
Owner transfer accidentally sent ERC20 tokens

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 Returns addition two unsigned integers , reverting
overflow
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
dev Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
dev Returns multiplication two unsigned integers , reverting
overflow
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
dev Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
dev Interface ERC20 standard defined EIP include
optional functions; access see `ERC20Detailed`
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
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 Implementation `IERC20` interface
implementation agnostic way tokens created means
supply mechanism added derived contract using ` mint`
generic mechanism see `ERC20Mintable`
detailed writeup see guide [How implement supply
mechanisms] ( https : forum zeppelin solutions implement erc20 supply mechanisms 226 )
followed general Open Zeppelin guidelines : functions revert instead
returning `false` failure behavior nonetheless conventional
conflict expectations ERC20 applications
Additionally , `Approval` event emitted calls `transfer From`
allows applications reconstruct allowance accounts
listening said events implementations EIP may emit
events , required specification
Finally , non standard `decrease Allowance` `increase Allowance`
functions added mitigate well known issues around setting
allowances See `IERC20 approve`
dev See `IERC20 total Supply`
dev See `IERC20 balance Of`
dev See `IERC20 transfer`
Requirements :
`recipient` cannot zero address
caller must balance least `amount`
dev See `IERC20 allowance`
dev See `IERC20 approve`
Requirements :
`spender` cannot zero address
dev See `IERC20 transfer From`
Emits `Approval` event indicating updated allowance
required EIP See note beginning `ERC20`;
Requirements :
`sender` `recipient` cannot zero address
`sender` must balance least `value`
caller must allowance `sender`'s tokens least
`amount`
dev Atomically increases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
dev Atomically decreases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
`spender` must allowance caller least
`subtracted Value`
dev Moves tokens `amount` `sender` `recipient`
internal function equivalent `transfer` , used
e g implement automatic token fees , slashing mechanisms , etc
Emits `Transfer` event
Requirements :
`sender` cannot zero address
`recipient` cannot zero address
`sender` must balance least `amount`
dev Creates `amount` tokens assigns `account` , increasing
total supply
Emits `Transfer` event `from` set zero address
Requirements
`to` cannot zero address
dev Destoys `amount` tokens `account` , reducing
total supply
Emits `Transfer` event `to` set zero address
Requirements
`account` cannot zero address
`account` must least `amount` tokens
dev Sets `amount` allowance `spender` `owner`s tokens
internal function equivalent `approve` , used
e g set automatic allowances certain subsystems , etc
Emits `Approval` event
Requirements :
`owner` cannot zero address
`spender` cannot zero address
dev Destoys `amount` tokens `account` `amount` deducted
caller's allowance
See ` burn` ` approve`
dev Optional functions ERC20 standard
dev Sets values `name` , `symbol` , `decimals` three
values immutable : set
construction
dev Returns name token
dev Returns symbol token , usually shorter version
name
dev Returns number decimals used get user representation
example , `decimals` equals `2` , balance `505` tokens
displayed user `5 , 05` ( `505 10 ** 2` )
Tokens usually opt value 18 , imitating relationship
Ether Wei
Note information used display purposes :
way affects arithmetic contract , including
`IERC20 balance Of` `IERC20 transfer`
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : github Open Zeppelin openzeppelin contracts pull 522
Solidity automatically asserts dividing 0
assert ( == b * c + % b ) ; case hold
github ethereum EIPs issues 20 issuecomment 263524729
forum zeppelin solutions implement erc20 supply mechanisms 226 ) *

MODIFIERS
require ( Valid Number ( result ) ) ;

compiles 0 5 0
'XQC' token contract
Symbol : XQC
Name : Quras Token
Total supply : 888888888
Decimals : 8
MIT Licence
Safe maths
contract library : compiler version
public internal : compiler version
public internal : compiler version
public internal : compiler version
public internal : compiler version
ERC Token Standard 20 Interface
https : github ethereum EIPs blob master EIPS eip 20 md
constant view : compiler version
constant view : compiler version
constant view : compiler version
Contract function receive approval execute function one call
Borrowed Mini Token
bytes memory : compiler version
Owned contract
function Owned constructor : compiler version
add emit : compiler version
ERC20 Token , addition symbol , name decimals assisted
fixed supply
Safe Math using Safe Math uint; : compiler version
unit public uint : compiler version
Constructor
function constructor : compiler version
direct address owner : compiler version
add emit , direct address owner : compiler version
Total supply
constant view : compiler version
Get token balance account `token Owner`
constant view : compiler version
Transfer balance token owner's account `to` account
Owner's account must sufficient balance transfer
0 value transfers allowed
add emit : compiler version
Token owner approve `spender` transfer ( ) `tokens`
token owner's account
https : github ethereum EIPs blob master EIPS eip 20 token standard md
recommends checks approval double spend attack
implemented user interfaces
add emit : compiler version
Transfer `tokens` `from` account `to` account
calling account must already sufficient tokens approve ( )
spending `from` account
account must sufficient balance transfer
Spender must sufficient allowance transfer
0 value transfers allowed
add emit : compiler version
Returns amount tokens approved owner
transferred spender's account
constant view : compiler version
Token owner approve `spender` transfer ( ) `tokens`
token owner's account `spender` contract function
`receive Approval ( ) ` executed
add emit : compiler version
Owner transfer accidentally sent ERC20 tokens

