719	1	*	source : etherscan
719	1	*	vulnerable lines : 29
719	1	*	yes report REENTRANCY
93	1	*	title Ownable
93	1	*	Ownable contract owner address , provides basic authorization control
93	1	*	functions , simplifies implementation "user permissions"
93	1	*	Ownable constructor sets original `owner` contract sender
93	1	*	Throws called account owner
93	1	*	Allows current owner transfer control contract new Owner
93	1	*	param new Owner address transfer ownership
93	1	*	Observer contract
93	1	*	Crowdsale contract
93	1	*	Manager stores permitted addresses
93	1	*	title Building Object contract
93	1	*	Vladimir Kovalchuk
93	1	*	Name object
93	1	*	Gross building area
93	1	*	Gress sale area
93	1	*	Parking space
93	1	*	Type building
93	1	*	Developer object
93	1	*	Location object
93	1	*	start project
93	1	*	end construction object
93	1	*	report completion
93	1	*	ERC223 Unity token
93	1	*	Hold contract
93	1	*	Permission manager contract
93	1	*	Constructor object
93	1	*	Public setters area
93	1	*	unt sqm
736	1	*	website : https : exclusiveplatform
736	1	*	title Safe Math
736	1	*	Multiplies two numbers , throws overflow
736	1	*	Integer division two numbers , truncating quotient
736	1	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
736	1	*	Adds two numbers , throws overflow
736	1	*	Ownable constructor sets original `owner` contract sender
736	1	*	Throws called account owner
736	1	*	Allows current owner transfer control contract new Owner
736	1	*	param new Owner address transfer ownership
736	1	*	20% bonus 5 eth
736	1	*	5% bonus 1 eth
736	1	*	limit withdrawal
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	ensure reward give
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	ensure reward give
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	limit withdrawal
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	mitigates ERC20 short address attack
736	1	*	suggested izqui9 @ : bit ly 2NMMCNv
736	1	*	limit withdrawal
736	1	*	limit withdrawal
736	1	*	ensure reward give
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	send user Balance[msg sender] ethers msg sender
736	1	*	mgs sender contract , call fallback function
736	1	*	@ actual transfer function token contract ,
736	1	*	called functions contract
736	1	*	@param address holding tokens transferred
736	1	*	@param address recipient
736	1	*	@param amount amount tokens transferred
736	1	*	@return True transfer successful
736	1	*	allow transfer 0x0 token contract
736	1	*	ensure reward give
736	1	*	limit withdrawal
736	1	*	@return balance ` owner`
736	1	*	ensure reward give
736	1	*	@notice `msg sender` approves ` spender` spend ` amount` tokens
736	1	*	behalf modified version ERC20 approve function
736	1	*	little bit safer
736	1	*	@param spender address account able transfer tokens
736	1	*	@param amount amount tokens approved transfer
736	1	*	@return True approval successful
736	1	*	change approve amount first reduce addresses`
736	1	*	allowance zero calling `approve ( spender , 0 ) `
736	1	*	already 0 mitigate race condition described :
736	1	*	https : ethereum EIPs issues 20 issuecomment 263524729
736	1	*	ensure reward give
736	1	*	limit withdrawal
717	1	*	source : etherscan
717	1	*	vulnerable lines : 29
717	1	*	yes report REENTRANCY
334	1	*	Interface defining crowdsale pricing
334	1	*	Interface declaration
334	1	*	Self check references correctly set
334	1	*	Checks pricing strategy matches crowdsale parameters
334	1	*	somebody tries buy tokens X eth , calculate many tokens get
334	1	*	param value value transaction send wei
334	1	*	param tokens Sold much tokens sold far
334	1	*	param wei Raised much money raised far
334	1	*	param msg Sender investor transaction
334	1	*	param decimals many decimal units token
334	1	*	return Amount tokens investor receives
334	1	*	ERC20 interface
334	1	*	see https : ethereum EIPs issues 20
334	1	*	Math operations safety checks
334	1	*	Standard ERC20 token Short Hand Attack approve ( ) race condition mitigation
334	1	*	Based code First Blood :
334	1	*	https : Firstbloodio token blob master smart contract First Blood Token sol
334	1	*	Token supply got increased new owner received tokens
334	1	*	Actual balances token holders
334	1	*	approve ( ) allowances
334	1	*	Interface declaration
334	1	*	ethereum EIPs issues 20
334	1	*	Firstbloodio token blob master smart contract First Blood Token sol
334	1	*	change approve amount first reduce addresses`
334	1	*	allowance zero calling `approve ( spender , 0 ) `
334	1	*	already 0 mitigate race condition described :
334	1	*	https : ethereum EIPs issues 20 issuecomment 263524729
334	1	*	coinschedule referral contract WWAM ICO
334	1	*	Holding number wei invested referral contract
72	1	*	title ERC20Basic
72	1	*	Simpler version ERC20 interface
72	1	*	see https : ethereum EIPs issues 179
72	1	*	title ERC20 interface
72	1	*	see https : ethereum EIPs issues 20
72	1	*	title Safe Math
72	1	*	Math operations safety checks throw error
72	1	*	Multiplies two numbers , throws overflow
72	1	*	Integer division two numbers , truncating quotient
72	1	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
72	1	*	Adds two numbers , throws overflow
72	1	*	title Safe ERC20
72	1	*	Wrappers around ERC20 operations throw failure
72	1	*	use library add `using Safe ERC20 ERC20;` statement contract ,
72	1	*	allows call safe operations `token safe Transfer ( ) ` , etc
72	1	*	title Ownable
72	1	*	Ownable contract owner address , provides basic authorization control
72	1	*	functions , simplifies implementation "user permissions"
72	1	*	Ownable constructor sets original `owner` contract sender
72	1	*	Throws called account owner
72	1	*	Allows current owner relinquish control contract
72	1	*	Allows current owner transfer control contract new Owner
72	1	*	param new Owner address transfer ownership
72	1	*	Transfers control contract new Owner
72	1	*	param new Owner address transfer ownership
72	1	*	title Contracts able recover tokens
72	1	*	Syl Ti
72	1	*	allow contract recover ERC20 token received contract transferring balance contract owner
72	1	*	prevent accidental loss tokens
72	1	*	Reclaim ERC20Basic compatible tokens
72	1	*	param token ERC20Basic address token contract
72	1	*	ethereum EIPs issues 179
72	1	*	ethereum EIPs issues 20
72	1	*	Gas optimization : cheaper asserting 'a' zero ,
72	1	*	benefit lost 'b' also tested
72	1	*	See : https : Open Zeppelin openzeppelin solidity pull 522
72	1	*	uint256 c = b;
72	1	*	including 0 LENGTH values
72	1	*	optimization total Supply
232	1	*	Public variables token
232	1	*	NOTE :
232	1	*	following variables OPTIONAL vanities One include
232	1	*	allow one customise token contract & way influences core functionality
232	1	*	wallets interfaces might even bother look information
232	1	*	Approves calls receiving contract
232	1	*	@return total amount tokens
232	1	*	@param owner address balance retrieved
232	1	*	@return balance
232	1	*	@notice send ` value` token ` to` `msg sender`
232	1	*	@param address recipient
232	1	*	@param value amount token transferred
232	1	*	@return Whether transfer successful
232	1	*	@notice send ` value` token ` to` ` from` condition approved ` from`
232	1	*	@param address sender
232	1	*	@param address recipient
232	1	*	@param value amount token transferred
232	1	*	@return Whether transfer successful
232	1	*	@notice `msg sender` approves ` addr` spend ` value` tokens
232	1	*	@param spender address account able transfer tokens
232	1	*	@param value amount wei approved transfer
232	1	*	@return Whether approval successful
232	1	*	@param owner address account owning tokens
232	1	*	@param spender address account able transfer tokens
232	1	*	@return Amount remaining tokens allowed spent
232	1	*	Default assumes total Supply can't max ( 2^256 1 )
232	1	*	token leaves total Supply issue tokens time goes , need check wrap
232	1	*	Replace one instead
232	1	*	( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
232	1	*	Replace line following want protect wrapping uints
232	1	*	( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
232	1	*	name contract whatever like
232	1	*	ether sent address , send back
232	1	*	fancy name : eg Simon Bucks
232	1	*	many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
232	1	*	identifier : eg SBX
232	1	*	human 0 1 standard arbitrary versioning scheme
232	1	*	CHANGE VALUES TOKEN
232	1	*	make sure function name matches contract name token called Tutorial Token , make sure contract name also Tutorial Token instead ERC20Token
232	1	*	Give creator initial tokens ( 100000 example )
232	1	*	Update total supply ( 100000 example )
232	1	*	Set name display purposes
232	1	*	Amount decimals display purposes
232	1	*	Set symbol display purposes
232	1	*	call receive Approval function contract want notified crafts function signature manually one include contract
232	1	*	receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
232	1	*	assumed call *should* succeed , otherwise one would use vanilla approve instead
711	1	*	source : etherscan
711	1	*	vulnerable lines : 54
711	1	*	yes report REENTRANCY
23	1	*	mitigates ERC20 short address attack
747	1	*	ensure reward give
747	1	*	send user Balance[msg sender] ethers msg sender
747	1	*	mgs sender contract , call fallback function
747	1	*	send user Balance[msg sender] ethers msg sender
747	1	*	mgs sender contract , call fallback function
747	1	*	ensure reward give
747	1	*	limit withdrawal
747	1	*	limit withdrawal
747	1	*	ensure reward give
747	1	*	limit withdrawal
747	1	*	ensure reward give
747	1	*	ensure reward give
747	1	*	send user Balance[msg sender] ethers msg sender
747	1	*	mgs sender contract , call fallback function
747	1	*	send user Balance[msg sender] ethers msg sender
747	1	*	mgs sender contract , call fallback function
747	1	*	limit withdrawal
367	1	*	last compiled soljson v0 3 5 6610add js
367	1	*	@return total amount tokens
367	1	*	@param owner address balance retrieved
367	1	*	@return balance
367	1	*	@notice send ` value` token ` to` `msg sender`
367	1	*	@param address recipient
367	1	*	@param value amount token transferred
367	1	*	@return Whether transfer successful
367	1	*	@notice send ` value` token ` to` ` from` condition approved ` from`
367	1	*	@param address sender
367	1	*	@param address recipient
367	1	*	@param value amount token transferred
367	1	*	@return Whether transfer successful
367	1	*	@notice `msg sender` approves ` addr` spend ` value` tokens
367	1	*	@param spender address account able transfer tokens
367	1	*	@param value amount wei approved transfer
367	1	*	@return Whether approval successful
367	1	*	@param owner address account owning tokens
367	1	*	@param spender address account able transfer tokens
367	1	*	@return Amount remaining tokens allowed spent
367	1	*	Default assumes total Supply can't max ( 2^256 1 )
367	1	*	token leaves total Supply issue tokens time goes , need check wrap
367	1	*	Replace one instead
367	1	*	( balances[msg sender] = value && value 0 ) {
367	1	*	Replace line following want protect wrapping uints
367	1	*	( balances[ from] = value && allowed[ from][msg sender] = value && value 0 ) {
367	1	*	Reality Keys :
367	1	*	percentage 1 ether
367	1	*	send X Ether , get X Yes tokens X tokens
15	1	*	title Safe Math
15	1	*	title Ownable
15	1	*	Ownable constructor sets original `owner` contract
15	1	*	sender account
15	1	*	Throws called account owner
15	1	*	Allows current owner transfer control contract new Owner
15	1	*	param new Owner address transfer ownership
15	1	*	title ERC223
15	1	*	title Contract Receiver
15	1	*	title Fight Money
15	1	*	ERC223 ERC20 functions events
15	1	*	ERC223 functions
15	1	*	ERC20 functions events
733	1	*	source : https : Consen Sys evm analyzer benchmark suite
733	1	*	vulnerable lines : 18
733	1	*	Consen Sys evm analyzer benchmark suite
733	1	*	yes report REENTRANCY
396	1	*	Provides information current execution context , including
396	1	*	sender transaction data generally available
396	1	*	via msg sender msg data , accessed direct
396	1	*	manner , since dealing meta transactions account sending
396	1	*	paying execution may actual sender ( far application
396	1	*	concerned )
396	1	*	contract required intermediate , library like contracts
396	1	*	Collection functions related address type
396	1	*	Returns true `account` contract
396	1	*	unsafe assume address function returns
396	1	*	false externally owned account ( EOA ) contract
396	1	*	Among others , `is Contract` return false following
396	1	*	types addresses :
396	1	*	externally owned account
396	1	*	contract construction
396	1	*	address contract created
396	1	*	address contract lived , destroyed
396	1	*	Replacement Solidity's `transfer` : sends `amount` wei
396	1	*	`recipient` , forwarding available gas reverting errors
396	1	*	https : eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
396	1	*	certain opcodes , possibly making contracts go 2300 gas limit
396	1	*	imposed `transfer` , making unable receive funds via
396	1	*	`transfer` {send Value} removes limitation
396	1	*	https : diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
396	1	*	IMPORTANT : control transferred `recipient` , care must
396	1	*	taken create reentrancy vulnerabilities Consider using
396	1	*	{Reentrancy Guard}
396	1	*	https : solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
396	1	*	Performs Solidity function call using low level `call`
396	1	*	plain`call` unsafe replacement function call : use
396	1	*	function instead
396	1	*	`target` reverts revert reason , bubbled
396	1	*	function ( like regular Solidity function calls )
396	1	*	Returns raw returned data convert expected return value ,
396	1	*	use https : solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
396	1	*	Requirements :
396	1	*	`target` must contract
396	1	*	calling `target` `data` must revert
396	1	*	Available since v3 1
396	1	*	{xref Address function Call address bytes }[`function Call`] ,
396	1	*	`error Message` fallback revert reason `target` reverts
396	1	*	Available since v3 1
396	1	*	{xref Address function Call address bytes }[`function Call`] ,
396	1	*	also transferring `value` wei `target`
396	1	*	Requirements :
396	1	*	calling contract must ETH balance least `value`
396	1	*	called Solidity function must `payable`
396	1	*	Available since v3 1
396	1	*	{xref Address function Call Value address bytes uint256 }[`function Call Value`] ,
396	1	*	`error Message` fallback revert reason `target` reverts
396	1	*	Available since v3 1
396	1	*	{xref Address function Call address bytes }[`function Call`] ,
396	1	*	performing static call
396	1	*	Available since v3 3
396	1	*	{xref Address function Call address bytes string }[`function Call`] ,
396	1	*	performing static call
396	1	*	Available since v3 3
396	1	*	{xref Address function Call address bytes }[`function Call`] ,
396	1	*	performing delegate call
396	1	*	Available since v3 4
396	1	*	{xref Address function Call address bytes string }[`function Call`] ,
396	1	*	performing delegate call
396	1	*	Available since v3 4
396	1	*	String operations
396	1	*	Converts `uint256` ASCII `string` decimal representation
396	1	*	Converts `uint256` ASCII `string` hexadecimal representation
396	1	*	Converts `uint256` ASCII `string` hexadecimal representation fixed length
396	1	*	Contract module provides basic access control mechanism ,
396	1	*	account ( owner ) granted exclusive access
396	1	*	specific functions
396	1	*	default , owner account one deploys contract
396	1	*	later changed {transfer Ownership}
396	1	*	module used inheritance make available modifier
396	1	*	`only Owner` , applied functions restrict use
396	1	*	Initializes contract setting deployer initial owner
396	1	*	Returns address current owner
396	1	*	Throws called account owner
396	1	*	Leaves contract without owner possible call
396	1	*	`only Owner` functions anymore called current owner
396	1	*	NOTE : Renouncing ownership leave contract without owner ,
396	1	*	thereby removing functionality available owner
396	1	*	Transfers ownership contract new account ( `new Owner` )
396	1	*	called current owner
396	1	*	Interface ERC165 standard , defined
396	1	*	https : eips ethereum org EIPS eip 165[EIP]
396	1	*	Implementers declare support contract interfaces ,
396	1	*	queried others ( {ERC165Checker} )
396	1	*	implementation , see {ERC165}
396	1	*	Returns true contract implements interface defined
396	1	*	`interface Id` See corresponding
396	1	*	https : eips ethereum org EIPS eip 165 interfaces identified[EIP section]
396	1	*	learn ids created
396	1	*	function call must use less 30 000 gas
396	1	*	Required interface ERC721 compliant contract
396	1	*	Emitted `token ID` token transferred `from` `to`
396	1	*	Emitted `owner` enables `approved` manage `token ID` token
396	1	*	Emitted `owner` enables disables ( `approved` ) `operator` manage assets
396	1	*	Returns number tokens ``owner``'s account
396	1	*	Returns owner `token ID` token
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	Safely transfers `token ID` token `from` `to` , checking first contract recipients
396	1	*	aware ERC721 protocol prevent tokens forever locked
396	1	*	Requirements :
396	1	*	`from` cannot zero address
396	1	*	`to` cannot zero address
396	1	*	`token ID` token must exist owned `from`
396	1	*	caller `from` , must allowed move token either {approve} {set Approval All}
396	1	*	`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
396	1	*	Emits {Transfer} event
396	1	*	Transfers `token ID` token `from` `to`
396	1	*	WARNING : Usage method discouraged , use {safe Transfer From} whenever possible
396	1	*	Requirements :
396	1	*	`from` cannot zero address
396	1	*	`to` cannot zero address
396	1	*	`token ID` token must owned `from`
396	1	*	caller `from` , must approved move token either {approve} {set Approval All}
396	1	*	Emits {Transfer} event
396	1	*	Gives permission `to` transfer `token ID` token another account
396	1	*	approval cleared token transferred
396	1	*	single account approved time , approving zero address clears previous approvals
396	1	*	Requirements :
396	1	*	caller must token approved operator
396	1	*	`token ID` must exist
396	1	*	Emits {Approval} event
396	1	*	Returns account approved `token ID` token
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	Approve remove `operator` operator caller
396	1	*	Operators call {transfer From} {safe Transfer From} token owned caller
396	1	*	Requirements :
396	1	*	`operator` cannot caller
396	1	*	Emits {Approval All} event
396	1	*	Returns `operator` allowed manage assets `owner`
396	1	*	See {set Approval All}
396	1	*	Safely transfers `token ID` token `from` `to`
396	1	*	Requirements :
396	1	*	`from` cannot zero address
396	1	*	`to` cannot zero address
396	1	*	`token ID` token must exist owned `from`
396	1	*	caller `from` , must approved move token either {approve} {set Approval All}
396	1	*	`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
396	1	*	Emits {Transfer} event
396	1	*	Implementation {IERC165} interface
396	1	*	Contracts want implement ERC165 inherit contract override {supports Interface} check
396	1	*	additional interface id supported example :
396	1	*	function supports Interface ( bytes4 interface Id ) public view virtual override returns ( bool ) {
396	1	*	return interface Id == type ( Interface ) interface Id || super supports Interface ( interface Id ) ;
396	1	*	Alternatively , {ERC165Storage} provides easier use expensive implementation
396	1	*	See {IERC165 supports Interface}
396	1	*	title ERC 721 Non Fungible Token Standard , optional metadata extension
396	1	*	See https : eips ethereum org EIPS eip 721
396	1	*	Returns token collection name
396	1	*	Returns token collection symbol
396	1	*	Returns Uniform Resource Identifier ( URI ) `token ID` token
396	1	*	Whenever {IERC721} `token ID` token transferred contract via {IERC721 safe Transfer From}
396	1	*	`operator` `from` , function called
396	1	*	must return Solidity selector confirm token transfer
396	1	*	value returned interface implemented recipient , transfer reverted
396	1	*	selector obtained Solidity `IERC721 ERC721Received selector`
396	1	*	Implementation https : eips ethereum org EIPS eip 721[ERC721] Non Fungible Token Standard , including
396	1	*	Metadata extension , including Enumerable extension , available separately
396	1	*	Initializes contract setting `name` `symbol` token collection
396	1	*	See {IERC165 supports Interface}
396	1	*	See {IERC721 balance Of}
396	1	*	See {IERC721 owner Of}
396	1	*	See {IERC721Metadata name}
396	1	*	See {IERC721Metadata symbol}
396	1	*	See {IERC721Metadata token URI}
396	1	*	Base URI computing {token URI} Empty default , overriden
396	1	*	child contracts
396	1	*	See {IERC721 approve}
396	1	*	See {IERC721 get Approved}
396	1	*	See {IERC721 set Approval All}
396	1	*	See {IERC721 Approved All}
396	1	*	See {IERC721 transfer From}
396	1	*	See {IERC721 safe Transfer From}
396	1	*	See {IERC721 safe Transfer From}
396	1	*	Safely transfers `token ID` token `from` `to` , checking first contract recipients
396	1	*	aware ERC721 protocol prevent tokens forever locked
396	1	*	` data` additional data , specified format sent call `to`
396	1	*	internal function equivalent {safe Transfer From} , used e g
396	1	*	implement alternative mechanisms perform token transfer , signature based
396	1	*	Requirements :
396	1	*	`from` cannot zero address
396	1	*	`to` cannot zero address
396	1	*	`token ID` token must exist owned `from`
396	1	*	`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
396	1	*	Emits {Transfer} event
396	1	*	Returns whether `token ID` exists
396	1	*	Tokens managed owner approved accounts via {approve} {set Approval All}
396	1	*	Tokens start existing minted ( ` mint` ) ,
396	1	*	stop existing burned ( ` burn` )
396	1	*	Returns whether `spender` allowed manage `token ID`
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	Safely mints `token ID` transfers `to`
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	`to` refers smart contract , must implement {IERC721Receiver ERC721Received} , called upon safe transfer
396	1	*	Emits {Transfer} event
396	1	*	{xref ERC721 safe Mint address uint256 }[` safe Mint`] , additional `data` parameter
396	1	*	forwarded {IERC721Receiver ERC721Received} contract recipients
396	1	*	Mints `token ID` transfers `to`
396	1	*	WARNING : Usage method discouraged , use { safe Mint} whenever possible
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	`to` cannot zero address
396	1	*	Emits {Transfer} event
396	1	*	Destroys `token ID`
396	1	*	approval cleared token burned
396	1	*	Requirements :
396	1	*	`token ID` must exist
396	1	*	Emits {Transfer} event
396	1	*	Transfers `token ID` `from` `to`
396	1	*	opposed {transfer From} , imposes restrictions msg sender
396	1	*	Requirements :
396	1	*	`to` cannot zero address
396	1	*	`token ID` token must owned `from`
396	1	*	Emits {Transfer} event
396	1	*	Approve `to` operate `token ID`
396	1	*	Emits {Approval} event
396	1	*	Internal function invoke {IERC721Receiver ERC721Received} target address
396	1	*	call executed target address contract
396	1	*	param address representing previous owner given token ID
396	1	*	param target address receive tokens
396	1	*	param token ID uint256 ID token transferred
396	1	*	param data bytes optional data send along call
396	1	*	return bool whether call correctly returned expected magic value
396	1	*	Hook called token transfer includes minting
396	1	*	Calling :
396	1	*	`from` `to` non zero , ``from``'s `token ID`
396	1	*	transferred `to`
396	1	*	`from` zero , `token ID` minted `to`
396	1	*	`to` zero , ``from``'s `token ID` burned
396	1	*	`from` cannot zero address
396	1	*	`to` cannot zero address
396	1	*	learn hooks , head xref : ROOT : extending contracts adoc using hooks[Using Hooks]
396	1	*	Emitted `new Admin Role` set ``role``'s admin role , replacing `previous Admin Role`
396	1	*	`DEFAULT ADMIN ROLE` starting admin roles , despite
396	1	*	{Role Admin Changed} emitted signaling
396	1	*	Available since v3 1
396	1	*	Emitted `account` granted `role`
396	1	*	`sender` account originated contract call , admin role
396	1	*	bearer except using { setup Role}
396	1	*	Emitted `account` revoked `role`
396	1	*	`sender` account originated contract call :
396	1	*	using `revoke Role` , admin role bearer
396	1	*	using `renounce Role` , role bearer ( e `account` )
396	1	*	Returns `true` `account` granted `role`
396	1	*	Returns admin role controls `role` See {grant Role}
396	1	*	{revoke Role}
396	1	*	change role's admin , use { set Role Admin}
396	1	*	Grants `role` `account`
396	1	*	`account` already granted `role` , emits {Role Granted}
396	1	*	Requirements :
396	1	*	caller must ``role``'s admin role
396	1	*	Revokes `role` `account`
396	1	*	`account` granted `role` , emits {Role Revoked} event
396	1	*	Requirements :
396	1	*	caller must ``role``'s admin role
396	1	*	Revokes `role` calling account
396	1	*	Roles often managed via {grant Role} {revoke Role} : function's
396	1	*	purpose provide mechanism accounts lose privileges
396	1	*	compromised ( trusted device misplaced )
396	1	*	calling account granted `role` , emits {Role Revoked}
396	1	*	Requirements :
396	1	*	caller must `account`
396	1	*	Grants `role` `account`
396	1	*	`account` already granted `role` , emits {Role Granted}
396	1	*	event Note unlike {grant Role} , function perform
396	1	*	checks calling account
396	1	*	function called constructor setting
396	1	*	initial roles system
396	1	*	Using function way effectively circumventing admin
396	1	*	system imposed {Access Control}
396	1	*	Sets `admin Role` ``role``'s admin role
396	1	*	Emits {Role Admin Changed} event
396	1	*	SPDX License Identifier : GPL 3 0
396	1	*	silence state mutability warning without generating bytecode see https : ethereum solidity issues 2691
396	1	*	method relies extcodesize , returns 0 contracts
396	1	*	construction , since code stored end
396	1	*	constructor execution
396	1	*	solhint disable next line inline assembly
396	1	*	eips ethereum org EIPS eip 1884[EIP1884] increases gas cost
396	1	*	diligence consensys net posts 2019 09 stop using soliditys transfer [Learn more]
396	1	*	solidity readthedocs en v0 5 11 security considerations html use checks effects interactions pattern[checks effects interactions pattern]
396	1	*	solhint disable next line avoid low level calls , avoid call value
396	1	*	solidity readthedocs en latest units global variables html ? highlight=abi decode abi encoding decoding functions[`abi decode`]
396	1	*	solhint disable next line avoid low level calls
396	1	*	solhint disable next line avoid low level calls
396	1	*	solhint disable next line avoid low level calls
396	1	*	Look revert reason bubble present
396	1	*	easiest way bubble revert reason using memory via assembly
396	1	*	solhint disable next line inline assembly
396	1	*	Inspired Oraclize API's implementation MIT licence
396	1	*	https : oraclize ethereum api blob b42146b063c7d6ee1358846c198246239e9360e8 oraclize API 0 4 25 sol
396	1	*	eips ethereum org EIPS eip 165[EIP]
396	1	*	eips ethereum org EIPS eip 165 interfaces identified[EIP section]
396	1	*	eips ethereum org EIPS eip 721
396	1	*	eips ethereum org EIPS eip 721[ERC721] Non Fungible Token Standard , including
396	1	*	Token name
396	1	*	Token symbol
396	1	*	Mapping token ID owner address
396	1	*	Mapping owner address token count
396	1	*	Mapping token ID approved address
396	1	*	Mapping owner operator approvals
396	1	*	solhint disable next line max line length
396	1	*	Clear approvals
396	1	*	Clear approvals previous owner
396	1	*	solhint disable next line inline assembly
396	1	*	Base Token URI
343	1	*	Originally https : Consen Sys Multi Sig Wallet
343	1	*	Public functions
343	1	*	Internal functions
343	1	*	Web3 call functions
343	1	*	Consen Sys Multi Sig Wallet
343	1	*	@title Multisignature wallet Allows multiple parties agree transactions execution
343	1	*	@ Stefan George [email protected]
343	1	*	@ Fallback function allows deposit ether
343	1	*	@ Contract constructor sets initial owners required number confirmations
343	1	*	@param owners List initial owners
343	1	*	@param required Number required confirmations
343	1	*	@ Allows add new owner Transaction sent wallet
343	1	*	@param owner Address new owner
343	1	*	@ Allows remove owner Transaction sent wallet
343	1	*	@param owner Address owner
343	1	*	@ Allows replace owner new owner Transaction sent wallet
343	1	*	@param owner Address owner replaced
343	1	*	@param owner Address new owner
343	1	*	@ Allows change number required confirmations Transaction sent wallet
343	1	*	@param required Number required confirmations
343	1	*	@ Allows owner submit confirm transaction
343	1	*	@param destination Transaction target address
343	1	*	@param value Transaction ether value
343	1	*	@param data Transaction data payload
343	1	*	@return Returns transaction ID
343	1	*	@ Allows owner confirm transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@ Allows owner revoke confirmation transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@ Allows anyone execute confirmed transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@ Returns confirmation status transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@return Confirmation status
343	1	*	@ Adds new transaction transaction mapping , transaction exist yet
343	1	*	@param destination Transaction target address
343	1	*	@param value Transaction ether value
343	1	*	@param data Transaction data payload
343	1	*	@return Returns transaction ID
343	1	*	@ Returns number confirmations transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@return Number confirmations
343	1	*	@ Returns total number transactions filers applied
343	1	*	@param pending Include pending transactions
343	1	*	@param executed Include executed transactions
343	1	*	@return Total number transactions filters applied
343	1	*	@ Returns list owners
343	1	*	@return List owner addresses
343	1	*	@ Returns array owner addresses , confirmed transaction
343	1	*	@param transaction Id Transaction ID
343	1	*	@return Returns array owner addresses
343	1	*	@ Returns list transaction IDs defined range
343	1	*	@param Index start position transaction array
343	1	*	@param Index end position transaction array
343	1	*	@param pending Include pending transactions
343	1	*	@param executed Include executed transactions
343	1	*	@return Returns array transaction IDs
97	1	*	title ERC20Basic
97	1	*	Simpler version ERC20 interface
97	1	*	see https : ethereum EIPs issues 179
97	1	*	title ERC20 interface
97	1	*	see https : ethereum EIPs issues 20
97	1	*	title Safe Math
97	1	*	Math operations safety checks throw error
97	1	*	Multiplies two numbers , throws overflow
97	1	*	Integer division two numbers , truncating quotient
97	1	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
97	1	*	Adds two numbers , throws overflow
97	1	*	title Safe ERC20
97	1	*	Wrappers around ERC20 operations throw failure
97	1	*	use library add `using Safe ERC20 ERC20;` statement contract ,
97	1	*	allows call safe operations `token safe Transfer ( ) ` , etc
97	1	*	title Ownable
97	1	*	Ownable contract owner address , provides basic authorization control
97	1	*	functions , simplifies implementation "user permissions"
97	1	*	Ownable constructor sets original `owner` contract sender
97	1	*	Throws called account owner
97	1	*	Allows current owner relinquish control contract
97	1	*	Allows current owner transfer control contract new Owner
97	1	*	param new Owner address transfer ownership
97	1	*	Transfers control contract new Owner
97	1	*	param new Owner address transfer ownership
97	1	*	title Contracts able recover tokens
97	1	*	Syl Ti
97	1	*	allow contract recover ERC20 token received contract transferring balance contract owner
97	1	*	prevent accidental loss tokens
97	1	*	Reclaim ERC20Basic compatible tokens
97	1	*	param token ERC20Basic address token contract
97	1	*	ethereum EIPs issues 179
97	1	*	ethereum EIPs issues 20
97	1	*	Gas optimization : cheaper asserting 'a' zero ,
97	1	*	benefit lost 'b' also tested
97	1	*	See : https : Open Zeppelin openzeppelin solidity pull 522
97	1	*	uint256 c = b;
97	1	*	including 0 LENGTH values
97	1	*	optimization total Supply
722	1	*	source : etherscan
722	1	*	vulnerable lines : 44
722	1	*	yes report REENTRANCY
27	1	*	title ERC20Basic
27	1	*	Simpler version ERC20 interface
27	1	*	see https : ethereum EIPs issues 179
27	1	*	title ERC20 interface
27	1	*	see https : ethereum EIPs issues 20
27	1	*	title Safe Math
27	1	*	Math operations safety checks throw error
27	1	*	Multiplies two numbers , throws overflow
27	1	*	Integer division two numbers , truncating quotient
27	1	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
27	1	*	Adds two numbers , throws overflow
27	1	*	title Safe ERC20
27	1	*	Wrappers around ERC20 operations throw failure
27	1	*	use library add `using Safe ERC20 ERC20;` statement contract ,
27	1	*	allows call safe operations `token safe Transfer ( ) ` , etc
27	1	*	title Ownable
27	1	*	Ownable contract owner address , provides basic authorization control
27	1	*	functions , simplifies implementation "user permissions"
27	1	*	Ownable constructor sets original `owner` contract sender
27	1	*	Throws called account owner
27	1	*	Allows current owner relinquish control contract
27	1	*	Allows current owner transfer control contract new Owner
27	1	*	param new Owner address transfer ownership
27	1	*	Transfers control contract new Owner
27	1	*	param new Owner address transfer ownership
27	1	*	title Contracts able recover tokens
27	1	*	Syl Ti
27	1	*	allow contract recover ERC20 token received contract transferring balance contract owner
27	1	*	prevent accidental loss tokens
27	1	*	Reclaim ERC20Basic compatible tokens
27	1	*	param token ERC20Basic address token contract
27	1	*	ethereum EIPs issues 179
27	1	*	ethereum EIPs issues 20
27	1	*	Gas optimization : cheaper asserting 'a' zero ,
27	1	*	benefit lost 'b' also tested
27	1	*	See : https : Open Zeppelin openzeppelin solidity pull 522
27	1	*	uint256 c = b;
27	1	*	including 0 LENGTH values
27	1	*	optimization total Supply
370	1	*	King Ether Throne Contracts
370	1	*	Copyright ( c ) 2016 Kieran Elby Released MIT License
370	1	*	Version 0 9 9 2 , July 2016
370	1	*	See also : www kingoftheether
370	1	*	https : kieranelby King Ether Throne
370	1	*	file contains number contracts ,
370	1	*	three normally created :
370	1	*	Kingdom = maintains throne kingdom
370	1	*	World = runs world , collection kingdoms
370	1	*	Kingdom Factory = used internally World contract
370	1	*	"Mixin" contracts ( Throne Rules Mixin , Reentry Protector Mixin ,
370	1	*	Careful Sender Mixin , Funds Holder Mixin , Money Rounder Mixin ,
370	1	*	Nameable Mixin ) contain functions data structures used
370	1	*	three main contracts
370	1	*	Exposed Internals Testing contract used automated tests
370	1	*	@title Mixin help avoid recursive call attacks
370	1	*	true inside external function
370	1	*	Mark contract entered external function
370	1	*	Throws exception called twice external Leave ( )
370	1	*	work , Contracts MUST :
370	1	*	call external Enter ( ) start external function
370	1	*	call external Leave ( ) end external function
370	1	*	never use return statements enter leave
370	1	*	never call external function another function
370	1	*	WARN : serious risk contract getting stuck used wrongly
370	1	*	Mark contract left external function
370	1	*	call external Enter ( )
370	1	*	@title Mixin help send ether untrusted addresses
370	1	*	Seems reasonable amount well written fallback function
370	1	*	Send ` value Wei` ether ` Address` , including
370	1	*	` extra Gas Included` gas usual 2300 gas stipend
370	1	*	send call
370	1	*	needs care way tell Address
370	1	*	externally owned another contract sending ether
370	1	*	contract address invoke fallback function;
370	1	*	three implications :
370	1	*	1 ) Danger recursive attack
370	1	*	destination contract's fallback function ( another
370	1	*	contract calls ) may call back contract ( including
370	1	*	fallback function external functions inherited ,
370	1	*	contracts stack ) , leading unexpected behaviour
370	1	*	Mitigations :
370	1	*	protect external functions entry
370	1	*	( see Reentry Protector Mixin ) ;
370	1	*	program defensively ( e g debit balance send )
370	1	*	2 ) Destination fallback function fail
370	1	*	destination contract's fallback function fails , ether
370	1	*	sent may locked sending contract
370	1	*	Unlike errors , cause contract throw
370	1	*	Mitigations :
370	1	*	check return value function ( see )
370	1	*	3 ) Gas usage
370	1	*	destination fallback function consume gas supplied
370	1	*	transaction ( fixed set transaction
370	1	*	starter , though clients good job estimating
370	1	*	problem lottery type contracts one
370	1	*	expensive call receiving contract could 'poison' lottery
370	1	*	contract preventing invoked another person
370	1	*	cannot supply enough gas
370	1	*	Mitigations :
370	1	*	choose sensible value extra Gas Included ( default
370	1	*	2300 gas supplied destination function ) ;
370	1	*	call fails consider whether throw ring fence
370	1	*	funds later withdrawal
370	1	*	Returns :
370	1	*	True send call made throw
370	1	*	error case , longer value Wei
370	1	*	ether Note cannot get return value fallback
370	1	*	function called ( )
370	1	*	False send made destination fallback function
370	1	*	threw error ( ran gas ) hapens , still
370	1	*	value Wei ether destination's actions undone
370	1	*	function normally throw error unless :
370	1	*	enough gas make send call
370	1	*	max call stack depth reached
370	1	*	insufficient ether
370	1	*	@title Mixin help track owns ether allow withdrawals
370	1	*	Record much wei owned address
370	1	*	Obviously , entries MUST backed actual ether
370	1	*	owned contract cannot enforce mixin
370	1	*	@notice Amount ether held ` address`
370	1	*	@notice Send caller ( `msg sender` ) ether
370	1	*	@notice Send ` value Wei` ether owned caller
370	1	*	( `msg sender` ) ` Address` , including ` extra Gas` gas
370	1	*	beyond normal stipend
370	1	*	@ internal version withdraw Funds ( )
370	1	*	@ internal version withdraw Funds Advanced ( ) , also used
370	1	*	withdraw Funds RP ( )
370	1	*	@title Mixin help make nicer looking ether amounts
370	1	*	@notice Make ` raw Value Wei` nicer , rounder number
370	1	*	@return value :
370	1	*	larger ` raw Value Wei`
370	1	*	smaller ` raw Value Wei` * 0 999
370	1	*	three significant figures UNLESS
370	1	*	number small large monetary terms
370	1	*	( define 1 finney 10000 ether ) ,
370	1	*	case precision lost
370	1	*	@notice Convert ` value Wei` whole number finney
370	1	*	@return smallest whole number finney equal
370	1	*	greater ` value Wei` converted wei
370	1	*	WARN : May incorrect ` value Wei` 2**254
370	1	*	@title Mixin help allow users name things
370	1	*	String manipulation expensive EVM; keep things short
370	1	*	@notice Check ` name` reasonable choice name
370	1	*	@return True ` name ` meets criteria
370	1	*	, false otherwise :
370	1	*	fewer 1 character
370	1	*	25 characters
370	1	*	characters :
370	1	*	"roman" alphabet letters ( Z z )
370	1	*	western digits ( 0 9 )
370	1	*	"safe" punctuation : ! ( ) SPACE
370	1	*	least one non punctuation character
370	1	*	Note deliberately exclude characters may cause
370	1	*	security problems websites databases escaping
370	1	*	performed correctly , " '
370	1	*	Apologies lack non English language support
370	1	*	Extract name bytes ` data` ( presumably `msg data` ) ,
370	1	*	throw exception data expected format
370	1	*	want make easy people name things , even
370	1	*	they're comfortable calling functions contracts
370	1	*	allow names sent fallback function encoded
370	1	*	message data
370	1	*	Unfortunately , way Ethereum Function ABI works means
370	1	*	must careful avoid clashes message data
370	1	*	represents names message data represents call
370	1	*	external function otherwise :
370	1	*	) names usable;
370	1	*	b ) small possibility phishing attack users
370	1	*	tricked using certain names cause external
370	1	*	function call e g data sent contract
370	1	*	keccak256 ( "withdraw Funds ( ) " ) withdrawal occur
370	1	*	require prefix "NAME : " start name ( encoded
370	1	*	ASCII ) sent via fallback function prefix
370	1	*	clash external function signature hashes
370	1	*	e g web3 Ascii ( 'NAME : ' + 'Joe Bloggs' )
370	1	*	WARN : check name "reasonableness";
370	1	*	use validate Name Internal ( )
370	1	*	check prefix present
370	1	*	copy data prefix
370	1	*	Turn short name "fuzzy hash" property
370	1	*	extremely similar names fuzzy hash
370	1	*	useful :
370	1	*	stop people choosing names differ case
370	1	*	punctuation would lead confusion
370	1	*	faciliate searching name without needing exact match
370	1	*	example , names fuzzy hash :
370	1	*	"Ba na na"
370	1	*	" banana "
370	1	*	"Banana long end ignored"
370	1	*	hand , "Banana1" "A Banana" different
370	1	*	WARN : likely work poorly names meet
370	1	*	validate Name Internal ( ) test
370	1	*	fold z Z
370	1	*	ignore others
370	1	*	@title Mixin help define rules throne
370	1	*	See World create Kingdom ( ) documentation
370	1	*	@title Maintains throne kingdom
370	1	*	e g "King Ether"
370	1	*	World contract used create kingdom , 0x0 none
370	1	*	rules govern kingdom see Throne Rules Mixin
370	1	*	Someone ruled ( ruling ) kingdom
370	1	*	send compensation
370	1	*	became ruler
370	1	*	claim price paid ( excluding payment )
370	1	*	compensation sent held far
370	1	*	first ruler number 1; zero th entry dummy entry
370	1	*	top Wizard earns half commission
370	1	*	normally owner World contract
370	1	*	sub Wizard earns half commission
370	1	*	normally creator Kingdom
370	1	*	top Wizard sub Wizard address
370	1	*	NB : also `funds` mapping Funds Holder Mixin ,
370	1	*	rentry Protector Reentry Protector Mixin
370	1	*	NB : also `Funds Withdrawn Event` Funds Holder Mixin
370	1	*	WARN validate arguments; MUST either call
370	1	*	Kingdom Factory validate Proposed Throne Rules ( ) create
370	1	*	Kingdom via Kingdom Factory World's create Kingdom ( )
370	1	*	See World create Kingdom ( ) parameter documentation
370	1	*	number monarchs starting 1; sometimes useful
370	1	*	use zero = invalid , put dummy entry number 0
370	1	*	zero th entry invalid
370	1	*	False either monarchs , latest monarch
370	1	*	reigned long struck curse
370	1	*	possible , think miners reject blocks
370	1	*	timestamps go backwards ? drift possible
370	1	*	needs handling unsigned overflow audit checks
370	1	*	@notice much must pay claim throne , wei
370	1	*	danger overflow claim price never gets high
370	1	*	@notice much must pay claim throne , finney
370	1	*	@notice Check name used monarch name
370	1	*	@return True name satisfies criteria :
370	1	*	fewer 1 character
370	1	*	25 characters
370	1	*	characters :
370	1	*	"roman" alphabet letters ( Z z )
370	1	*	western digits ( 0 9 )
370	1	*	"safe" punctuation : ! ( ) SPACE
370	1	*	Get details latest monarch ( even dead )
370	1	*	expose externally returning structs well
370	1	*	supported ABI ( strange monarchs Number array works
370	1	*	fine though ) Note reference returned writable
370	1	*	used update details latest monarch
370	1	*	WARN : check number Monarchs ( ) 0 first
370	1	*	@notice Claim throne sending funds contract
370	1	*	future compensation earned sent sender's
370	1	*	address ( `msg sender` )
370	1	*	Sending contract recommended unless know
370	1	*	( tested )
370	1	*	message data supplied , throne claimed
370	1	*	name "Anonymous" supply name , send data encoded
370	1	*	using web3 Ascii ( 'NAME : ' + 'your chosen valid name' )
370	1	*	Sender must include payment equal current Claim Price Wei ( )
370	1	*	consume ~300 , 000 gas
370	1	*	throw error :
370	1	*	name invalid ( see `validate Proposed Monarch Name ( string ) ` )
370	1	*	payment low high
370	1	*	Produces events :
370	1	*	`Throne Claimed Event`
370	1	*	`Compensation Sent Event` `Compensation Fail Event`
370	1	*	`Commission Earned Event`
370	1	*	@notice Claim throne given ` monarch Name`
370	1	*	future compensation earned sent caller's
370	1	*	address ( `msg sender` )
370	1	*	Caller must include payment equal current Claim Price Wei ( )
370	1	*	Calling contract recommended unless know
370	1	*	( tested )
370	1	*	consume ~300 , 000 gas
370	1	*	throw error :
370	1	*	name invalid ( see `validate Proposed Monarch Name ( string ) ` )
370	1	*	payment low high
370	1	*	Produces events :
370	1	*	`Throne Claimed Event
370	1	*	`Compensation Sent Event` `Compensation Fail Event`
370	1	*	`Commission Earned Event`
370	1	*	@notice Used either top Wizard sub Wizard transfer
370	1	*	rights future commissions ` replacement` wizard
370	1	*	WARN : original wizard retains ownership past
370	1	*	commission held `funds` mapping ,
370	1	*	still withdraw
370	1	*	Produces event Wizard Replaced Event
370	1	*	Make easy people pay using whole number finney ,
370	1	*	could teeny bit higher raw wei value
370	1	*	dead men get compensation
370	1	*	case teeny excess , use official price
370	1	*	since determine new claim price , paid Wei
370	1	*	Careful top Wizard sub Wizard address ,
370	1	*	case must replace
370	1	*	Allow commission funds build contract wizards
370	1	*	withdraw ( carefully ring fenced )
370	1	*	give sub Wizard "odd" single wei
370	1	*	Send compensation latest monarch ( hold funds
370	1	*	cannot fault current caller )
370	1	*	record compensated
370	1	*	WARN : latest monarch contract whose fallback
370	1	*	function needs 25300 gas
370	1	*	receive compensation automatically
370	1	*	happen latest monarch contract
370	1	*	whose fallback function failed ran gas ( despite
370	1	*	us including fair amount gas )
370	1	*	throw since want throne get
370	1	*	'stuck' ( new usurpers fault ) instead save
370	1	*	funds could send claimed later
370	1	*	monarch contract would need designed
370	1	*	call withdraw Funds Advanced ( ) function mind
370	1	*	@title Used World contract create Kingdom instances
370	1	*	@ Mostly exists top Wizard potentially replace
370	1	*	contract modify Kingdom contract rule validation
370	1	*	logic used *future* Kingdoms created World
370	1	*	implement rentry protection send call
370	1	*	charge fee bypass World
370	1	*	listed official World page course
370	1	*	contract never balance
370	1	*	See World create Kingdom ( ) parameter documentation
370	1	*	suppose danger massive deflation inflation could
370	1	*	change real world sanity checks , case
370	1	*	deploy new factory update world
370	1	*	@notice Create new Kingdom Normally called World contract
370	1	*	WARN : validate kingdom Name world arguments
370	1	*	consume 1 , 800 , 000 gas ( ! )
370	1	*	throw error :
370	1	*	rules invalid ( see validate Proposed Throne Rules )
370	1	*	wizard addresses "obviously" wrong
370	1	*	gas quite likely ( perhaps future consider
370	1	*	using solidity libraries reduce Kingdom size ? )
370	1	*	See World create Kingdom ( ) parameter documentation
370	1	*	contract never balance
370	1	*	NB : top Wizard sub Wizard
370	1	*	@title Runs world , collection Kingdoms
370	1	*	top Wizard runs world charge creation
370	1	*	kingdoms become top Wizard kingdom created
370	1	*	much one must pay create new kingdom ( wei )
370	1	*	changed top Wizard
370	1	*	first kingdom number 1; zero th entry dummy
370	1	*	safety , cap high price get
370	1	*	changed top Wizard , though affect
370	1	*	kingdoms created
370	1	*	Helper contract creating Kingdom instances
370	1	*	upgraded top Wizard ( affect existing ones )
370	1	*	Avoids duplicate kingdom names allows searching name
370	1	*	NB : also `funds` mapping Funds Holder Mixin ,
370	1	*	rentry Protector Reentry Protector Mixin
370	1	*	NB : also `Funds Withdrawn Event` Funds Holder Mixin
370	1	*	Create world kingdoms yet
370	1	*	Costs 1 9M gas deploy
370	1	*	number kingdoms starting 1 since sometimes
370	1	*	useful use zero = invalid Create dummy zero th entry
370	1	*	@return index kingdoms Number found , zero
370	1	*	@notice Check name used kingdom name
370	1	*	@return True name satisfies criteria :
370	1	*	fewer 1 character
370	1	*	25 characters
370	1	*	characters :
370	1	*	"roman" alphabet letters ( Z z )
370	1	*	western digits ( 0 9 )
370	1	*	"safe" punctuation : ! ( ) SPACE
370	1	*	WARN : check name already use;
370	1	*	use `find Kingdom Called ( string ) ` afterwards
370	1	*	Check rules would allowed new custom Kingdom
370	1	*	Typically used calling `create Kingdom ( ) `
370	1	*	much one must pay create new kingdom ( finney )
370	1	*	changed top Wizard
370	1	*	Reject funds sent contract wizards cannot interact
370	1	*	via API able withdraw commission
370	1	*	@notice Create new kingdom using custom rules
370	1	*	@param kingdom Name \
370	1	*	e g "King Ether Throne"
370	1	*	@param starting Claim Price Wei \
370	1	*	much cost first monarch claim throne
370	1	*	( also price death monarch )
370	1	*	@param claim Price Adjust Percent \
370	1	*	Percentage increase claim e g claim price
370	1	*	200 ETH , ` claim Price Adjust Percent` 50 , next
370	1	*	claim price 200 ETH + ( 50% 200 ETH ) = 300 ETH
370	1	*	@param curse Incubation Duration Seconds \
370	1	*	maximum length time monarch rule
370	1	*	curse strikes removed without compensation
370	1	*	@param commission Per Thousand \
370	1	*	much payment given wizards share ,
370	1	*	expressed parts per thousand e g 25 means 25 1000 ,
370	1	*	Caller must include payment equal kingdom Creation Fee Wei
370	1	*	caller become 'sub wizard' earn half
370	1	*	commission charged Kingdom Note however
370	1	*	need call withdraw Funds ( ) Kingdom contract
370	1	*	get commission send automatically
370	1	*	consume 1 , 900 , 000 gas ( ! )
370	1	*	throw error :
370	1	*	name invalid ( see `validate Proposed Kingdom Name ( string ) ` )
370	1	*	name already use ( see `find Kingdom Called ( string ) ` )
370	1	*	rules invalid ( see `validate Proposed Kingdom Rules ( ) ` )
370	1	*	payment low high
370	1	*	insufficient gas ( quite likely ! )
370	1	*	Produces event Kingdom Created Event
370	1	*	@notice Used top Wizard transfer rights future
370	1	*	fees future kingdom wizardships ` replacement` wizard
370	1	*	WARN : original wizard retains ownership past fees
370	1	*	held `funds` mapping , still
370	1	*	withdraw also remain top Wizard existing Kingdoms
370	1	*	Produces event Wizard Replaced Event
370	1	*	@notice Used top Wizard vary fee creating kingdoms
370	1	*	@notice Used top Wizard vary cap claim price
370	1	*	@notice Used top Wizard vary factory contract
370	1	*	used create future Kingdoms
370	1	*	Make easy people pay using whole number finney ,
370	1	*	could teeny bit higher raw wei value
370	1	*	perform rule validation
370	1	*	existing kingdom called ` kingdom Name` , create
370	1	*	record mapping name kingdom ` new Kingdom Number`
370	1	*	Throws error existing kingdom (
370	1	*	fuzzily similar see compute Name Fuzzy Hash ) name exists
370	1	*	@title Used testnet allow automated testing internals
759	1	*	ensure reward give
759	1	*	send user Balance[msg sender] ethers msg sender
759	1	*	mgs sender contract , call fallback function
759	1	*	send user Balance[msg sender] ethers msg sender
759	1	*	mgs sender contract , call fallback function
759	1	*	limit withdrawal
759	1	*	limit withdrawal
759	1	*	limit withdrawal
759	1	*	ensure reward give
759	1	*	send user Balance[msg sender] ethers msg sender
759	1	*	mgs sender contract , call fallback function
759	1	*	send user Balance[msg sender] ethers msg sender
759	1	*	mgs sender contract , call fallback function
759	1	*	ensure reward give
759	1	*	limit withdrawal
759	1	*	ensure reward give
759	1	*	require ( Valid Number ( result ) ) ;
162	1	*	implements standard functions NOTHING else
162	1	*	token like would want deploy something like Mist , see Human Standard Token sol
162	1	*	deploy , anything useful
162	1	*	Implements ERC 20 Token standard : https : ethereum EIPs issues 20
162	1	*	Token Contract implements standard token functionality ( https : ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
162	1	*	words intended deployment something like Token Factory Mist wallet , used humans
162	1	*	Imagine coins , currencies , shares , voting weight , etc
162	1	*	Machine based , rapid creation many tokens would necessarily need extra features minted manners
162	1	*	1 ) Initial Finite Supply ( upon creation one specifies much minted )
162	1	*	2 ) absence token registry : Optional Decimal , Symbol & Name
162	1	*	3 ) Optional approve Call ( ) functionality notify contract approval ( ) occurred
162	1	*	Public variables token
162	1	*	NOTE :
162	1	*	following variables OPTIONAL vanities One include
162	1	*	allow one customise token contract & way influences core functionality
162	1	*	wallets interfaces might even bother look information
162	1	*	Approves calls receiving contract
162	1	*	@return total amount tokens
162	1	*	@param owner address balance retrieved
162	1	*	@return balance
162	1	*	@notice send ` value` token ` to` `msg sender`
162	1	*	@param address recipient
162	1	*	@param value amount token transferred
162	1	*	@return Whether transfer successful
162	1	*	@notice send ` value` token ` to` ` from` condition approved ` from`
162	1	*	@param address sender
162	1	*	@param address recipient
162	1	*	@param value amount token transferred
162	1	*	@return Whether transfer successful
162	1	*	@notice `msg sender` approves ` addr` spend ` value` tokens
162	1	*	@param spender address account able transfer tokens
162	1	*	@param value amount wei approved transfer
162	1	*	@return Whether approval successful
162	1	*	@param owner address account owning tokens
162	1	*	@param spender address account able transfer tokens
162	1	*	@return Amount remaining tokens allowed spent
162	1	*	ethereum EIPs issues 20
162	1	*	Default assumes total Supply can't max ( 2^256 1 )
162	1	*	token leaves total Supply issue tokens time goes , need check wrap
162	1	*	Replace one instead
162	1	*	( balances[msg sender] = value && balances[ to] + value balances[ to] ) {
162	1	*	Replace line following want protect wrapping uints
162	1	*	( balances[ from] = value && allowed[ from][msg sender] = value && balances[ to] + value balances[ to] ) {
162	1	*	ethereum EIPs issues 20 ) well following OPTIONAL extras intended use humans
162	1	*	ether sent address , send back
162	1	*	fancy name : eg Simon Bucks
162	1	*	many decimals show ie could 1000 base units 3 decimals Meaning 0 980 SBX = 980 base units like comparing 1 wei 1 ether
162	1	*	identifier : eg SBX
162	1	*	human 0 1 standard arbitrary versioning scheme
162	1	*	Give creator initial tokens
162	1	*	Update total supply
162	1	*	Set name display purposes
162	1	*	Amount decimals display purposes
162	1	*	Set symbol display purposes
162	1	*	call receive Approval function contract want notified crafts function signature manually one include contract
162	1	*	receive Approval ( address , uint256 value , address token Contract , bytes extra Data )
162	1	*	assumed call *should* succeed , otherwise one would use vanilla approve instead
728	1	*	source : etherscan
728	1	*	vulnerable lines : 63
728	1	*	yes report REENTRANCY
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	limit withdrawal
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	ensure reward give
746	1	*	ensure reward give
746	1	*	limit withdrawal
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	limit withdrawal
746	1	*	fee whitelist
746	1	*	limit withdrawal
746	1	*	limit withdrawal
746	1	*	transfer amount zero
746	1	*	emit event stop execution
746	1	*	Calculate receiver balance
746	1	*	initial receive full value
746	1	*	Change sender balance
746	1	*	transaction whitelisted
746	1	*	calculate fees
746	1	*	Subtract fees receiver amount
746	1	*	Burn tokens
746	1	*	Transfer balance Dan Pan
746	1	*	Sanity checks
746	1	*	tokens created
746	1	*	Add tokens receiver
746	1	*	ensure reward give
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	send user Balance[msg sender] ethers msg sender
746	1	*	mgs sender contract , call fallback function
746	1	*	transfer amount zero
746	1	*	emit event stop execution
746	1	*	Calculate receiver balance
746	1	*	initial receive full value
746	1	*	Change sender balance
746	1	*	transaction whitelisted
746	1	*	calculate fees
746	1	*	Subtract fees receiver amount
746	1	*	Burn tokens
746	1	*	Transfer balance Dan Pan
746	1	*	Sanity checks
746	1	*	tokens created
746	1	*	Add tokens receiver
746	1	*	ensure reward give
746	1	*	limit withdrawal
746	1	*	ensure reward give
746	1	*	ensure reward give
28	1	*	title ERC20Basic
28	1	*	Simpler version ERC20 interface
28	1	*	see https : ethereum EIPs issues 179
28	1	*	title ERC20 interface
28	1	*	see https : ethereum EIPs issues 20
28	1	*	title Safe Math
28	1	*	Math operations safety checks throw error
28	1	*	Multiplies two numbers , throws overflow
28	1	*	Integer division two numbers , truncating quotient
28	1	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
28	1	*	Adds two numbers , throws overflow
28	1	*	title Safe ERC20
28	1	*	Wrappers around ERC20 operations throw failure
28	1	*	use library add `using Safe ERC20 ERC20;` statement contract ,
28	1	*	allows call safe operations `token safe Transfer ( ) ` , etc
28	1	*	title Ownable
28	1	*	Ownable contract owner address , provides basic authorization control
28	1	*	functions , simplifies implementation "user permissions"
28	1	*	Ownable constructor sets original `owner` contract sender
28	1	*	Throws called account owner
28	1	*	Allows current owner relinquish control contract
28	1	*	Allows current owner transfer control contract new Owner
28	1	*	param new Owner address transfer ownership
28	1	*	Transfers control contract new Owner
28	1	*	param new Owner address transfer ownership
28	1	*	title Contracts able recover tokens
28	1	*	Syl Ti
28	1	*	allow contract recover ERC20 token received contract transferring balance contract owner
28	1	*	prevent accidental loss tokens
28	1	*	Reclaim ERC20Basic compatible tokens
28	1	*	param token ERC20Basic address token contract
28	1	*	ethereum EIPs issues 179
28	1	*	ethereum EIPs issues 20
28	1	*	Gas optimization : cheaper asserting 'a' zero ,
28	1	*	benefit lost 'b' also tested
28	1	*	See : https : Open Zeppelin openzeppelin solidity pull 522
28	1	*	uint256 c = b;
28	1	*	including 0 LENGTH values
28	1	*	optimization total Supply
169	1	*	notice get balance specific address
169	1	*	contract user attempts get coins
169	1	*	Allow another contract user spend tokens behalf
169	1	*	Check sender enough
169	1	*	Check overflows
169	1	*	Check allowance
169	1	*	Subtract sender
169	1	*	Add recipient
169	1	*	contract name | contract info
169	1	*	ERC20 Events
169	1	*	ERC223 Event
