Bodhi Ethereum
ERC20
This contract is an ERC20 token.
Name
Bodhi Ethereum
Symbol
BOE
Decimals
8
Total Supply
100,000,000 BOE
About
Stats
Public Functions
9
Event Types
5
Code Size
8,643 bytes
Events (5) keyboard_arrow_up
Functions
transferOwnership keyboard_arrow_up
Modifiers help
onlyOwner checks for the following:
validAddress checks for the following:
Source Code
function transferOwnership(address _newOwner)
public
onlyOwner
validAddress(_newOwner)
{
emit OwnershipTransferred(owner, _newOwner);
owner = _newOwner;
}
transfer keyboard_arrow_up
approve keyboard_arrow_up
Requirements help
One or more of the following:
Source Code
function approve(address _spender, uint256 _value) public returns (bool) {
// 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.com/ethereum/EIPs/issues/20#issuecomment-263524729
require((_value == 0) || (allowed[msg.sender][_spender] == 0));
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender, _value);
return true;
}
transferFrom keyboard_arrow_up
Source Code
function transferFrom(
address _from,
address _to,
uint256 _value
) public validAddress(_to) returns (bool) {
uint256 _allowance = allowed[_from][msg.sender];
// Check is not needed because sub(_allowance, _value) will already throw if this condition is not met
// require (_value <= _allowance);
balances[_from] = balances[_from].sub(_value);
balances[_to] = balances[_to].add(_value);
allowed[_from][msg.sender] = _allowance.sub(_value);
emit Transfer(_from, _to, _value);
return true;
}
balanceOf keyboard_arrow_up
allowance keyboard_arrow_up
transfer keyboard_arrow_up
Source Code
function transfer(
address _to,
uint256 _value,
bytes _data
) public validAddress(_to) returns (bool success) {
uint256 codeLength;
assembly {
// Retrieve the size of the code on target address, this needs assembly
codeLength := extcodesize(_to)
}
balances[msg.sender] = balances[msg.sender].sub(_value);
balances[_to] = balances[_to].add(_value);
// Call token fallback function if _to is a contract. Rejects if not implemented.
if (codeLength > 0) {
ERC223ReceivingContract(_to).tokenFallback(msg.sender, _value, _data);
}
emit Transfer(msg.sender, _to, _value);
emit Transfer(msg.sender, _to, _value, _data);
return true;
}
tokenTotalSupply keyboard_arrow_up
mint keyboard_arrow_up
Modifiers help
onlyOwner checks for the following:
Requirements help
Source Code
function mint(address _to, uint256 _amount) external onlyOwner returns (bool) {
require(totalSupply.add(_amount) <= tokenTotalSupply());
totalSupply = totalSupply.add(_amount);
balances[_to] = balances[_to].add(_amount);
emit Mint(totalSupply, _to, _amount);
emit Transfer(address(0), _to, _amount);
return true;
}
Internal Functions
Internal functions are parts of the contract that can't be used directly, but instead are used by the public functions listed above.