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