Blockwell

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

Approval Event

Parameters help
owner
address help
spender
address help
value
uint256 help

Mint Event

Parameters help
supply
uint256 help
to
address help
amount
uint256 help

OwnershipTransferred Event

Parameters help
_previousOwner
address help
_newOwner
address help

Transfer Event

Parameters help
from
address help
to
address help
value
uint256 help

Transfer Event

Parameters help
from
address help
to
address help
value
uint256 help
data
bytes help

name Constant

string help
Bodhi Ethereum

symbol Constant

string help
BOE

decimals Constant

uint256 help
8

totalSupply Variable

uint256 help

owner Variable

address help

balances Variable

mapping(address => uint256) help
Internal Variable

allowed Variable

mapping(address => mapping(address => uint256)) help
Internal Variable

Functions Expand All Collapse All

transferOwnership keyboard_arrow_up

Parameters help

Name Type
_newOwner
address help

Properties

Visibility help public
Mutability help transaction
Source Code
function transferOwnership(address _newOwner)
  public
  onlyOwner
  validAddress(_newOwner)
{
  emit OwnershipTransferred(owner, _newOwner);
  owner = _newOwner;
}

Parameters help

Name Type
_to
address help
_value
uint256 help

Properties

Visibility help public
Mutability help transaction
Source Code
function transfer(address _to, uint256 _value) public returns (bool) {
  bytes memory empty;
  transfer(_to, _value, empty);
}

Parameters help

Name Type
_spender
address help
_value
uint256 help

Properties

Visibility help public
Mutability help transaction

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;
}

Parameters help

Name Type
_from
address help
_to
address help
_value
uint256 help

Properties

Visibility help public
Mutability help transaction

Modifiers help

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;
}

Parameters help

Name Type
_owner
address help

Properties

Visibility help public
Mutability help view
Source Code
function balanceOf(address _owner) public view returns (uint256 balance) {
  return balances[_owner];
}

Parameters help

Name Type
_owner
address help
_spender
address help

Properties

Visibility help public
Mutability help view
Source Code
function allowance(address _owner, address _spender)
  public
  view
  returns (uint256 remaining)
{
  return allowed[_owner][_spender];
}

Parameters help

Name Type
_to
address help
_value
uint256 help
_data
bytes help

Properties

Visibility help public
Mutability help transaction

Modifiers help

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

Parameters help

This function has no parameters.

Properties

Visibility help public
Mutability help pure
Source Code
function tokenTotalSupply() public pure returns (uint256) {
  return 100 * (10**6) * (10**decimals);
}

mint keyboard_arrow_up

Parameters help

Name Type
_to
address help
_amount
uint256 help

Properties

Visibility help public
Mutability help transaction

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 Expand All Collapse All

Internal functions are parts of the contract that can't be used directly, but instead are used by the public functions listed above.