Contract 0xe14a603f7c77d4101a87859b8736a04cfd85c688

 

TxHash Block Age From To Value [TxFee]
0xb6311911a401ce19534375bfdcb2cb3ede5a3014c57bf954117a05b2abc81bbb740422315 hrs 7 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078288
0xf77b5a8ede8fef71432720f94884b406d967cb55565855185bd933f6be5a9eee740361517 hrs 22 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000054208
0x1f253306f21952a0c90786059fe9e183a91e9e3703b081f39d2734365eedc401740310219 hrs 17 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078288
0xbfb4ad58cb0a0426ed5a6dea7cf821609311807980e32fe9adb45e1d1201e315740296619 hrs 47 mins ago0x049236fcda397704b34a28dda9b55c01add80c1a IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000039144
0xb0ca8ca91dd1a88cdaa6c04a11d1cb83220cd93d35c660c9ee86fd0b0b6ac8b2740247621 hrs 31 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078416
0xc22c437cbb3b8031d3c42280b9136b82c744ee126c66a3e44658da8c7943444d740242521 hrs 43 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078416
0x9f7b39f3163855f454c31d07463461a870ae2c1d21c88cafdb6afbd21803c4eb740238621 hrs 53 mins ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078416
0x7688a0f59f1b5ba52189b8a3eb1f5fd795af1fdb63ec42ce81ae162435b1101073995621 day 8 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000216832
0x7e7b6750428cea10a49498f1e77ccb1b8d8cce8debcf5d3942efbe7df3e5009273994361 day 8 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078416
0x0e6909ebf4441de67a46ca325c033839667163411f0b40b361bd56192076578c73993401 day 9 hrs ago0x2f94ce9886e1aaaa99084c7a9af5e08ea99c247c IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000207872
0xee2afddf78031cbdd093491c65a1fe286fa607b0febf6338f9bfcde48e76180973993371 day 9 hrs ago0x2f94ce9886e1aaaa99084c7a9af5e08ea99c247c IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000193152
0x7b049d58eadb75c7b043785db0703c1b11bdac5a126653b790fb26ca6faa58e273985211 day 12 hrs ago0xf61f8b59f4377d8beb7b5943cc580a1f7461143a IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.0019572
0x45e949f45a79f0818a06b8af626cc4eba040d3bac4a9c084dae97b8e320fe8c073976931 day 15 hrs ago0xbda3093ef23c964932dbf089c2e660f7deeeee5c IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000024207999
0x5dbc46bd0d2c5237660fd252ceffba428460c3e05af4cf9e535fdf6baea99bd773974771 day 16 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000054208
0xda1c5e01c118663ccd72368e80ce8817611f0a38b421bb5d01f08232586f364073971911 day 17 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000108416
0x8a0a6c628f0a0a00377034d4732ab1d1982dc14125b1ffd04ddf86ad68f09add73967691 day 18 hrs ago0xf411a7e8e6079a0d1e107ee945ef6fb648f39aa7 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000155904
0x0d71c694f0d1737047307ae0e601942c1464313ef66c6f9a91caa0e47e5e4a5573967661 day 18 hrs ago0xf411a7e8e6079a0d1e107ee945ef6fb648f39aa7 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000144864
0x0b6995c8faaf1afea0aef3f3781c2ba23d68b2d605cebfac779a448608939c8573966431 day 19 hrs ago0x92b1be696c89c27337c4bf5a829e40a6997f3431 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000048288
0xf830340a425c4aa9e72c43e91f1d42747690dee3062252fb8f043740e2fac51f73966261 day 19 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000039208
0xdf77fbdb7207f5df24a8ca62887a60f29c9cb1ca3a26b4b5d10b56e5a9e5748173918152 days 13 hrs ago0x9fd83ebd9ca3363a62ac5f09f28d308956184bf3 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000195931588
0xe7f5d390c49b39189cabae1af4d87281a8a6d49da5df3628f4f111f2e830d74573910812 days 16 hrs ago0x72fa106ff81136652c83814b1c84d90323726bff IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.00108416
0x0709b919c4a4df3c090da518efad86b1d3199ab4c0031edefdaf32bc6f99785973909032 days 17 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000039208
0x732aab1fffd5ec2e5967ebf3026130a1237f3c30b911d74ca63da8eee46ebcdd73908992 days 17 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000054208
0x18b0d43f22954f2396ebff1a124dd4b5f377b03fa0fcc1c081a7b0aafbfc288e73908112 days 17 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.000078288
0xe8d97e8ce2452633fb48d8e6ab37f5a56c650290df5b64e8b43353d2341892be73903602 days 19 hrs ago0xe33f22375f7f9b0596e479ace95ef8282aeeae31 IN  0xe14a603f7c77d4101a87859b8736a04cfd85c6880 Ether0.00007816
[ Download CSV Export 

Internal Transactions as a result of Contract Execution

Parent TxHash Block Age From To Value
Warning: The compiled contract might be susceptible to ExpExponentCleanup (medium/high-severity), EventStructWrongData (very low-severity) Solidity Compiler Bugs.

Contract Source Code Verified (Exact Match)

Contract Name:
TENA

Compiler Version
v0.4.24+commit.e67f0147

Optimization Enabled:
Yes

Runs (Optimizer):
200

Contract Source Code

pragma solidity ^0.4.24;

/**
 * @title Ownable
 * @dev The Ownable contract has an owner address, and provides basic authorization control
 * functions, this simplifies the implementation of "user permissions".
 */
contract Ownable {
  address private _owner;

  event OwnershipTransferred(
    address indexed previousOwner,
    address indexed newOwner
  );

  /**
   * @dev The Ownable constructor sets the original `owner` of the contract to the sender
   * account.
   */
  constructor() internal {
    _owner = msg.sender;
    emit OwnershipTransferred(address(0), _owner);
  }

  /**
   * @return the address of the owner.
   */
  function owner() public view returns(address) {
    return _owner;
  }

  /**
   * @dev Throws if called by any account other than the owner.
   */
  modifier onlyOwner() {
    require(isOwner());
    _;
  }

  /**
   * @return true if `msg.sender` is the owner of the contract.
   */
  function isOwner() public view returns(bool) {
    return msg.sender == _owner;
  }

  /**
   * @dev Allows the current owner to relinquish control of the contract.
   * @notice Renouncing to ownership will leave the contract without an owner.
   * It will not be possible to call the functions with the `onlyOwner`
   * modifier anymore.
   */
  function renounceOwnership() public onlyOwner {
    emit OwnershipTransferred(_owner, address(0));
    _owner = address(0);
  }

  /**
   * @dev Allows the current owner to transfer control of the contract to a newOwner.
   * @param newOwner The address to transfer ownership to.
   */
  function transferOwnership(address newOwner) public onlyOwner {
    _transferOwnership(newOwner);
  }

  /**
   * @dev Transfers control of the contract to a newOwner.
   * @param newOwner The address to transfer ownership to.
   */
  function _transferOwnership(address newOwner) internal {
    require(newOwner != address(0));
    emit OwnershipTransferred(_owner, newOwner);
    _owner = newOwner;
  }
}

/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
interface IERC20 {
  function totalSupply() external view returns (uint256);

  function balanceOf(address who) external view returns (uint256);

  function allowance(address owner, address spender)
    external view returns (uint256);

  function transfer(address to, uint256 value) external returns (bool);

  function approve(address spender, uint256 value)
    external returns (bool);

  function transferFrom(address from, address to, uint256 value)
    external returns (bool);

  event Transfer(
    address indexed from,
    address indexed to,
    uint256 value
  );

  event Approval(
    address indexed owner,
    address indexed spender,
    uint256 value
  );
}

/**
 * @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.
 */
contract ERC20Detailed is IERC20 {
  string private _name;
  string private _symbol;
  uint8 private _decimals;

  constructor(string name, string symbol, uint8 decimals) public {
    _name = name;
    _symbol = symbol;
    _decimals = decimals;
  }

  /**
   * @return the name of the token.
   */
  function name() public view returns(string) {
    return _name;
  }

  /**
   * @return the symbol of the token.
   */
  function symbol() public view returns(string) {
    return _symbol;
  }

  /**
   * @return the number of decimals of the token.
   */
  function decimals() public view returns(uint8) {
    return _decimals;
  }
}

/**
 * @title SafeMath
 * @dev Math operations with safety checks that revert on error
 */
library SafeMath {

  /**
  * @dev Multiplies two numbers, reverts on overflow.
  */
  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
    // benefit is lost if 'b' is also tested.
    // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
    if (a == 0) {
      return 0;
    }

    uint256 c = a * b;
    require(c / a == b);

    return c;
  }

  /**
  * @dev Integer division of two numbers truncating the quotient, reverts on division by zero.
  */
  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b > 0); // Solidity only automatically asserts when dividing by 0
    uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold

    return c;
  }

  /**
  * @dev Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend).
  */
  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b <= a);
    uint256 c = a - b;

    return c;
  }

  /**
  * @dev Adds two numbers, reverts on overflow.
  */
  function add(uint256 a, uint256 b) internal pure returns (uint256) {
    uint256 c = a + b;
    require(c >= a);

    return c;
  }

  /**
  * @dev Divides two numbers and returns the remainder (unsigned integer modulo),
  * reverts when dividing by zero.
  */
  function mod(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b != 0);
    return a % b;
  }
}

/**
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md
 * Originally based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
contract ERC20 is IERC20 {
  using SafeMath for uint256;

  mapping (address => uint256) private _balances;

  mapping (address => mapping (address => uint256)) private _allowed;

  uint256 private _totalSupply;

  /**
  * @dev Total number of tokens in existence
  */
  function totalSupply() public view returns (uint256) {
    return _totalSupply;
  }

  /**
  * @dev Gets the balance of the specified address.
  * @param owner The address to query the balance of.
  * @return An uint256 representing the amount owned by the passed address.
  */
  function balanceOf(address owner) public view returns (uint256) {
    return _balances[owner];
  }

  /**
   * @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.
   */
  function allowance(
    address owner,
    address spender
   )
    public
    view
    returns (uint256)
  {
    return _allowed[owner][spender];
  }

  /**
  * @dev Transfer token for a specified address
  * @param to The address to transfer to.
  * @param value The amount to be transferred.
  */
  function transfer(address to, uint256 value) public returns (bool) {
    _transfer(msg.sender, to, value);
    return true;
  }

  /**
   * @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.com/ethereum/EIPs/issues/20#issuecomment-263524729
   * @param spender The address which will spend the funds.
   * @param value The amount of tokens to be spent.
   */
  function approve(address spender, uint256 value) public returns (bool) {
    require(spender != address(0));

    _allowed[msg.sender][spender] = value;
    emit Approval(msg.sender, spender, value);
    return true;
  }

  /**
   * @dev Transfer tokens from one address to another
   * @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
   */
  function transferFrom(
    address from,
    address to,
    uint256 value
  )
    public
    returns (bool)
  {
    require(value <= _allowed[from][msg.sender]);

    _allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
    _transfer(from, to, value);
    return true;
  }

  /**
   * @dev Increase the amount of tokens that an owner allowed to a spender.
   * approve should be called when allowed_[_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 MonolithDAO Token.sol
   * @param spender The address which will spend the funds.
   * @param addedValue The amount of tokens to increase the allowance by.
   */
  function increaseAllowance(
    address spender,
    uint256 addedValue
  )
    public
    returns (bool)
  {
    require(spender != address(0));

    _allowed[msg.sender][spender] = (
      _allowed[msg.sender][spender].add(addedValue));
    emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
    return true;
  }

  /**
   * @dev Decrease the amount of tokens that an owner allowed to a spender.
   * approve should be called when allowed_[_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 MonolithDAO Token.sol
   * @param spender The address which will spend the funds.
   * @param subtractedValue The amount of tokens to decrease the allowance by.
   */
  function decreaseAllowance(
    address spender,
    uint256 subtractedValue
  )
    public
    returns (bool)
  {
    require(spender != address(0));

    _allowed[msg.sender][spender] = (
      _allowed[msg.sender][spender].sub(subtractedValue));
    emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
    return true;
  }

  /**
  * @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.
  */
  function _transfer(address from, address to, uint256 value) internal {
    require(value <= _balances[from]);
    require(to != address(0));

    _balances[from] = _balances[from].sub(value);
    _balances[to] = _balances[to].add(value);
    emit Transfer(from, to, value);
  }

  /**
   * @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.
   */
  function _mint(address account, uint256 value) internal {
    require(account != 0);
    _totalSupply = _totalSupply.add(value);
    _balances[account] = _balances[account].add(value);
    emit Transfer(address(0), account, value);
  }

  /**
   * @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.
   */
  function _burn(address account, uint256 value) internal {
    require(account != 0);
    require(value <= _balances[account]);

    _totalSupply = _totalSupply.sub(value);
    _balances[account] = _balances[account].sub(value);
    emit Transfer(account, address(0), value);
  }

  /**
   * @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.
   * @param account The account whose tokens will be burnt.
   * @param value The amount that will be burnt.
   */
  function _burnFrom(address account, uint256 value) internal {
    require(value <= _allowed[account][msg.sender]);

    // Should https://github.com/OpenZeppelin/zeppelin-solidity/issues/707 be accepted,
    // this function needs to emit an event with the updated approval.
    _allowed[account][msg.sender] = _allowed[account][msg.sender].sub(
      value);
    _burn(account, value);
  }
}

/**
 * @title Roles
 * @dev Library for managing addresses assigned to a Role.
 */
library Roles {
  struct Role {
    mapping (address => bool) bearer;
  }

  /**
   * @dev give an account access to this role
   */
  function add(Role storage role, address account) internal {
    require(account != address(0));
    require(!has(role, account));

    role.bearer[account] = true;
  }

  /**
   * @dev remove an account's access to this role
   */
  function remove(Role storage role, address account) internal {
    require(account != address(0));
    require(has(role, account));

    role.bearer[account] = false;
  }

  /**
   * @dev check if an account has this role
   * @return bool
   */
  function has(Role storage role, address account)
    internal
    view
    returns (bool)
  {
    require(account != address(0));
    return role.bearer[account];
  }
}

contract MinterRole {
  using Roles for Roles.Role;

  event MinterAdded(address indexed account);
  event MinterRemoved(address indexed account);

  Roles.Role private minters;

  constructor() internal {
    _addMinter(msg.sender);
  }

  modifier onlyMinter() {
    require(isMinter(msg.sender));
    _;
  }

  function isMinter(address account) public view returns (bool) {
    return minters.has(account);
  }

  function addMinter(address account) public onlyMinter {
    _addMinter(account);
  }

  function renounceMinter() public {
    _removeMinter(msg.sender);
  }

  function _addMinter(address account) internal {
    minters.add(account);
    emit MinterAdded(account);
  }

  function _removeMinter(address account) internal {
    minters.remove(account);
    emit MinterRemoved(account);
  }
}

/**
 * @title ERC20Mintable
 * @dev ERC20 minting logic
 */
contract ERC20Mintable is ERC20, MinterRole {
  /**
   * @dev Function to mint tokens
   * @param to The address that will receive the minted tokens.
   * @param value The amount of tokens to mint.
   * @return A boolean that indicates if the operation was successful.
   */
  function mint(
    address to,
    uint256 value
  )
    public
    onlyMinter
    returns (bool)
  {
    _mint(to, value);
    return true;
  }
}

/**
 * @title Capped token
 * @dev Mintable token with a token cap.
 */
contract ERC20Capped is ERC20Mintable {

  uint256 private _cap;

  constructor(uint256 cap)
    public
  {
    require(cap > 0);
    _cap = cap;
  }

  /**
   * @return the cap for the token minting.
   */
  function cap() public view returns(uint256) {
    return _cap;
  }

  function _mint(address account, uint256 value) internal {
    require(totalSupply().add(value) <= _cap);
    super._mint(account, value);
  }
}

/**
 * @title Burnable Token
 * @dev Token that can be irreversibly burned (destroyed).
 */
contract ERC20Burnable is ERC20 {

  /**
   * @dev Burns a specific amount of tokens.
   * @param value The amount of token to be burned.
   */
  function burn(uint256 value) public {
    _burn(msg.sender, value);
  }

  /**
   * @dev Burns a specific amount of tokens from the target address and decrements allowance
   * @param from address The address which you want to send tokens from
   * @param value uint256 The amount of token to be burned
   */
  function burnFrom(address from, uint256 value) public {
    _burnFrom(from, value);
  }
}

contract BurnerRole {
  using Roles for Roles.Role;

  event BurnerAdded(address indexed account);
  event BurnerRemoved(address indexed account);

  Roles.Role private burners;

  constructor() internal {
    _addBurner(msg.sender);
  }

  modifier onlyBurner() {
    require(isBurner(msg.sender));
    _;
  }

  function isBurner(address account) public view returns (bool) {
    return burners.has(account);
  }

  function addBurner(address account) public onlyBurner {
    _addBurner(account);
  }

  function renounceBurner() public {
    _removeBurner(msg.sender);
  }

  function _addBurner(address account) internal {
    burners.add(account);
    emit BurnerAdded(account);
  }

  function _removeBurner(address account) internal {
    burners.remove(account);
    emit BurnerRemoved(account);
  }
}

/**
 * @title Burnable Token
 * @dev Token that can be irreversibly burned (destroyed).
 */
contract ERC20SafeBurnable is ERC20Burnable, BurnerRole {

  /**
   * @dev Burns a specific amount of tokens.
   * @param value The amount of token to be burned.
   */
  function burn(uint256 value) public onlyBurner {
    super._burn(msg.sender, value);
  }

  /**
   * @dev Burns a specific amount of tokens from the target address and decrements allowance
   * @param from address The address which you want to send tokens from
   * @param value uint256 The amount of token to be burned
   */
  function burnFrom(address from, uint256 value) public onlyBurner {
    super._burnFrom(from, value);
  }
}

contract PauserRole {
  using Roles for Roles.Role;

  event PauserAdded(address indexed account);
  event PauserRemoved(address indexed account);

  Roles.Role private pausers;

  constructor() internal {
    _addPauser(msg.sender);
  }

  modifier onlyPauser() {
    require(isPauser(msg.sender));
    _;
  }

  function isPauser(address account) public view returns (bool) {
    return pausers.has(account);
  }

  function addPauser(address account) public onlyPauser {
    _addPauser(account);
  }

  function renouncePauser() public {
    _removePauser(msg.sender);
  }

  function _addPauser(address account) internal {
    pausers.add(account);
    emit PauserAdded(account);
  }

  function _removePauser(address account) internal {
    pausers.remove(account);
    emit PauserRemoved(account);
  }
}

/**
 * @title Pausable
 * @dev Base contract which allows children to implement an emergency stop mechanism.
 */
contract Pausable is PauserRole {
  event Paused(address account);
  event Unpaused(address account);

  bool private _paused;

  constructor() internal {
    _paused = false;
  }

  /**
   * @return true if the contract is paused, false otherwise.
   */
  function paused() public view returns(bool) {
    return _paused;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is not paused.
   */
  modifier whenNotPaused() {
    require(!_paused);
    _;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is paused.
   */
  modifier whenPaused() {
    require(_paused);
    _;
  }

  /**
   * @dev called by the owner to pause, triggers stopped state
   */
  function pause() public onlyPauser whenNotPaused {
    _paused = true;
    emit Paused(msg.sender);
  }

  /**
   * @dev called by the owner to unpause, returns to normal state
   */
  function unpause() public onlyPauser whenPaused {
    _paused = false;
    emit Unpaused(msg.sender);
  }
}

/**
 * @title Pausable token
 * @dev ERC20 modified with pausable transfers.
 **/
contract ERC20Pausable is ERC20, Pausable {

  function transfer(
    address to,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.transfer(to, value);
  }

  function transferFrom(
    address from,
    address to,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.transferFrom(from, to, value);
  }

  function approve(
    address spender,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.approve(spender, value);
  }

  function increaseAllowance(
    address spender,
    uint addedValue
  )
    public
    whenNotPaused
    returns (bool success)
  {
    return super.increaseAllowance(spender, addedValue);
  }

  function decreaseAllowance(
    address spender,
    uint subtractedValue
  )
    public
    whenNotPaused
    returns (bool success)
  {
    return super.decreaseAllowance(spender, subtractedValue);
  }
}

contract TENA is Ownable, ERC20Detailed, ERC20Capped, ERC20SafeBurnable, ERC20Pausable {
    using SafeMath for uint;
    
    // token variables
    string private constant NAME = "TENA";
    string private constant SYMBOL = "TENA";
    uint8 private constant DECIMALS = 18;
    uint private constant TOTAL_SUPPLY = 100000000;  // 100,000,000 TENA
    
    // initial lock
    bool isTransferable = false;
    
    // freeze address
    mapping (address => bool) freezed;
    
    constructor () public
        ERC20Detailed(NAME, SYMBOL, DECIMALS)
        ERC20Capped(TOTAL_SUPPLY.mul(10 ** uint(DECIMALS))) {
    }
    
    function unlock() external onlyOwner {
        isTransferable = true;
    }
    
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
        if (!isOwner()) {
            require(isTransferable);
            require(!(freezed[_from] || freezed[_to]));
        }
        return super.transferFrom(_from, _to, _value);
    }

    function transfer(address _to, uint256 _value) public returns (bool) {
        if (!isOwner()) {
            require(isTransferable);
            require(!(freezed[msg.sender] || freezed[_to]));
        }
        return super.transfer(_to, _value);
    }
    
    function freeze(address at) external onlyOwner {
        setFreezed(at, true);
    }
    
    function unfreeze(address at) external onlyOwner {
        setFreezed(at, false);
    }
    
    function setFreezed(address at, bool freezing) public onlyOwner {
        freezed[at] = freezing;
    }

    function isFreezed(address at) public view returns (bool) {
        return freezed[at];
    }
    
    // overload mint
    function mint(uint256 value) public onlyMinter returns (bool) {
        _mint(msg.sender, value);
        return true;
    }
}

Contract ABI

[{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"value","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_from","type":"address"},{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"cap","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"value","type":"uint256"}],"name":"mint","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"value","type":"uint256"}],"name":"burn","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"isBurner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"at","type":"address"}],"name":"unfreeze","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"isPauser","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renouncePauser","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"value","type":"uint256"}],"name":"burnFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"at","type":"address"}],"name":"isFreezed","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"account","type":"address"}],"name":"addPauser","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"at","type":"address"}],"name":"freeze","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"account","type":"address"}],"name":"addMinter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"renounceMinter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"value","type":"uint256"}],"name":"mint","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"at","type":"address"},{"name":"freezing","type":"bool"}],"name":"setFreezed","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"unlock","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"isMinter","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"},{"name":"spender","type":"address"}],"name":"allowance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceBurner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"account","type":"address"}],"name":"addBurner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"PauserAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"PauserRemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"BurnerAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"BurnerRemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"MinterAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"MinterRemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"spender","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"}]

Contract Creation Code

6080604052600b805461ff00191690553480156200001c57600080fd5b50620000436305f5e100670de0b6b3a76400006401000000006200159d6200017382021704565b60408051808201825260048082527f54454e410000000000000000000000000000000000000000000000000000000060208084018290528451808601865292835282015260008054600160a060020a0319163317808255935192939192601292600160a060020a031691907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a38251620000e890600190602086019062000339565b508151620000fe90600290602085019062000339565b506003805460ff191660ff92909216919091179055506200012a905033640100000000620001b0810204565b600081116200013857600080fd5b6008556200014f3364010000000062000202810204565b620001633364010000000062000254810204565b600b805460ff19169055620003de565b600080831515620001885760009150620001a9565b508282028284828115156200019957fe5b0414620001a557600080fd5b8091505b5092915050565b620001cb60078264010000000062001452620002a682021704565b604051600160a060020a038216907f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f690600090a250565b6200021d60098264010000000062001452620002a682021704565b604051600160a060020a038216907f86e57fd2b90329052917118de7c3f521f400d439b9650deaa906a25b08b9456090600090a250565b6200026f600a8264010000000062001452620002a682021704565b604051600160a060020a038216907f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f890600090a250565b600160a060020a0381161515620002bc57600080fd5b620002d1828264010000000062000301810204565b15620002dc57600080fd5b600160a060020a0316600090815260209190915260409020805460ff19166001179055565b6000600160a060020a03821615156200031957600080fd5b50600160a060020a03166000908152602091909152604090205460ff1690565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106200037c57805160ff1916838001178555620003ac565b82800160010185558215620003ac579182015b82811115620003ac5782518255916020019190600101906200038f565b50620003ba929150620003be565b5090565b620003db91905b80821115620003ba5760008155600101620003c5565b90565b6115f780620003ee6000396000f3006080604052600436106101cc5763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde0381146101d1578063095ea7b31461025b57806318160ddd1461029357806323b872dd146102ba578063313ce567146102e4578063355274ea1461030f57806339509351146103245780633f4ba83a1461034857806340c10f191461035f57806342966c68146103835780634334614a1461039b57806345c8b1a6146103bc57806346fbf68e146103dd5780635c975abb146103fe5780636ef8d66d1461041357806370a0823114610428578063715018a61461044957806379cc67901461045e5780638111f24e1461048257806382dc1ec4146104a35780638456cb59146104c45780638d1fdf2f146104d95780638da5cb5b146104fa5780638f32d59b1461052b57806395d89b4114610540578063983b2d56146105555780639865027514610576578063a0712d681461058b578063a0790cb7146105a3578063a457c2d7146105c9578063a69df4b5146105ed578063a9059cbb14610602578063aa271e1a14610626578063dd62ed3e14610647578063e9ec9e8b1461066e578063f2fde38b14610683578063f44637ba146106a4575b600080fd5b3480156101dd57600080fd5b506101e66106c5565b6040805160208082528351818301528351919283929083019185019080838360005b83811015610220578181015183820152602001610208565b50505050905090810190601f16801561024d5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561026757600080fd5b5061027f600160a060020a036004351660243561075a565b604080519115158252519081900360200190f35b34801561029f57600080fd5b506102a861077e565b60408051918252519081900360200190f35b3480156102c657600080fd5b5061027f600160a060020a0360043581169060243516604435610784565b3480156102f057600080fd5b506102f9610806565b6040805160ff9092168252519081900360200190f35b34801561031b57600080fd5b506102a861080f565b34801561033057600080fd5b5061027f600160a060020a0360043516602435610815565b34801561035457600080fd5b5061035d610832565b005b34801561036b57600080fd5b5061027f600160a060020a0360043516602435610896565b34801561038f57600080fd5b5061035d6004356108bf565b3480156103a757600080fd5b5061027f600160a060020a03600435166108e0565b3480156103c857600080fd5b5061035d600160a060020a03600435166108f9565b3480156103e957600080fd5b5061027f600160a060020a0360043516610917565b34801561040a57600080fd5b5061027f61092a565b34801561041f57600080fd5b5061035d610933565b34801561043457600080fd5b506102a8600160a060020a036004351661093e565b34801561045557600080fd5b5061035d610959565b34801561046a57600080fd5b5061035d600160a060020a03600435166024356109c3565b34801561048e57600080fd5b5061027f600160a060020a03600435166109e5565b3480156104af57600080fd5b5061035d600160a060020a0360043516610a03565b3480156104d057600080fd5b5061035d610a20565b3480156104e557600080fd5b5061035d600160a060020a0360043516610a86565b34801561050657600080fd5b5061050f610aa4565b60408051600160a060020a039092168252519081900360200190f35b34801561053757600080fd5b5061027f610ab3565b34801561054c57600080fd5b506101e6610ac4565b34801561056157600080fd5b5061035d600160a060020a0360043516610b22565b34801561058257600080fd5b5061035d610b3f565b34801561059757600080fd5b5061027f600435610b48565b3480156105af57600080fd5b5061035d600160a060020a03600435166024351515610b70565b3480156105d557600080fd5b5061027f600160a060020a0360043516602435610bae565b3480156105f957600080fd5b5061035d610bcb565b34801561060e57600080fd5b5061027f600160a060020a0360043516602435610bef565b34801561063257600080fd5b5061027f600160a060020a0360043516610c5f565b34801561065357600080fd5b506102a8600160a060020a0360043581169060243516610c72565b34801561067a57600080fd5b5061035d610c9d565b34801561068f57600080fd5b5061035d600160a060020a0360043516610ca6565b3480156106b057600080fd5b5061035d600160a060020a0360043516610cc2565b60018054604080516020601f600260001961010087891615020190951694909404938401819004810282018101909252828152606093909290918301828280156107505780601f1061072557610100808354040283529160200191610750565b820191906000526020600020905b81548152906001019060200180831161073357829003601f168201915b5050505050905090565b600b5460009060ff161561076d57600080fd5b6107778383610cdf565b9392505050565b60065490565b600061078e610ab3565b15156107f357600b54610100900460ff1615156107aa57600080fd5b600160a060020a0384166000908152600c602052604090205460ff16806107e95750600160a060020a0383166000908152600c602052604090205460ff165b156107f357600080fd5b6107fe848484610d5d565b949350505050565b60035460ff1690565b60085490565b600b5460009060ff161561082857600080fd5b6107778383610d7b565b61083b33610917565b151561084657600080fd5b600b5460ff16151561085757600080fd5b600b805460ff191690556040805133815290517f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa9181900360200190a1565b60006108a133610c5f565b15156108ac57600080fd5b6108b68383610e2b565b50600192915050565b6108c8336108e0565b15156108d357600080fd5b6108dd3382610e5b565b50565b60006108f360098363ffffffff610f2b16565b92915050565b610901610ab3565b151561090c57600080fd5b6108dd816000610b70565b60006108f3600a8363ffffffff610f2b16565b600b5460ff1690565b61093c33610f62565b565b600160a060020a031660009081526004602052604090205490565b610961610ab3565b151561096c57600080fd5b60008054604051600160a060020a03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36000805473ffffffffffffffffffffffffffffffffffffffff19169055565b6109cc336108e0565b15156109d757600080fd5b6109e18282610faa565b5050565b600160a060020a03166000908152600c602052604090205460ff1690565b610a0c33610917565b1515610a1757600080fd5b6108dd8161103c565b610a2933610917565b1515610a3457600080fd5b600b5460ff1615610a4457600080fd5b600b805460ff191660011790556040805133815290517f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2589181900360200190a1565b610a8e610ab3565b1515610a9957600080fd5b6108dd816001610b70565b600054600160a060020a031690565b600054600160a060020a0316331490565b60028054604080516020601f60001961010060018716150201909416859004938401819004810282018101909252828152606093909290918301828280156107505780601f1061072557610100808354040283529160200191610750565b610b2b33610c5f565b1515610b3657600080fd5b6108dd81611084565b61093c336110cc565b6000610b5333610c5f565b1515610b5e57600080fd5b610b683383610e2b565b506001919050565b610b78610ab3565b1515610b8357600080fd5b600160a060020a03919091166000908152600c60205260409020805460ff1916911515919091179055565b600b5460009060ff1615610bc157600080fd5b6107778383611114565b610bd3610ab3565b1515610bde57600080fd5b600b805461ff001916610100179055565b6000610bf9610ab3565b1515610c5557600b54610100900460ff161515610c1557600080fd5b336000908152600c602052604090205460ff1680610c4b5750600160a060020a0383166000908152600c602052604090205460ff165b15610c5557600080fd5b610777838361115f565b60006108f360078363ffffffff610f2b16565b600160a060020a03918216600090815260056020908152604080832093909416825291909152205490565b61093c3361117c565b610cae610ab3565b1515610cb957600080fd5b6108dd816111c4565b610ccb336108e0565b1515610cd657600080fd5b6108dd81611241565b6000600160a060020a0383161515610cf657600080fd5b336000818152600560209081526040808320600160a060020a03881680855290835292819020869055805186815290519293927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a350600192915050565b600b5460009060ff1615610d7057600080fd5b6107fe848484611289565b6000600160a060020a0383161515610d9257600080fd5b336000908152600560209081526040808320600160a060020a0387168452909152902054610dc6908363ffffffff61132616565b336000818152600560209081526040808320600160a060020a0389168085529083529281902085905580519485525191937f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929081900390910190a350600192915050565b600854610e4682610e3a61077e565b9063ffffffff61132616565b1115610e5157600080fd5b6109e18282611343565b600160a060020a0382161515610e7057600080fd5b600160a060020a038216600090815260046020526040902054811115610e9557600080fd5b600654610ea8908263ffffffff6113ef16565b600655600160a060020a038216600090815260046020526040902054610ed4908263ffffffff6113ef16565b600160a060020a0383166000818152600460209081526040808320949094558351858152935191937fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929081900390910190a35050565b6000600160a060020a0382161515610f4257600080fd5b50600160a060020a03166000908152602091909152604090205460ff1690565b610f73600a8263ffffffff61140616565b604051600160a060020a038216907fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e90600090a250565b600160a060020a0382166000908152600560209081526040808320338452909152902054811115610fda57600080fd5b600160a060020a038216600090815260056020908152604080832033845290915290205461100e908263ffffffff6113ef16565b600160a060020a03831660009081526005602090815260408083203384529091529020556109e18282610e5b565b61104d600a8263ffffffff61145216565b604051600160a060020a038216907f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f890600090a250565b61109560078263ffffffff61145216565b604051600160a060020a038216907f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f690600090a250565b6110dd60078263ffffffff61140616565b604051600160a060020a038216907fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb6669290600090a250565b6000600160a060020a038316151561112b57600080fd5b336000908152600560209081526040808320600160a060020a0387168452909152902054610dc6908363ffffffff6113ef16565b600b5460009060ff161561117257600080fd5b61077783836114a0565b61118d60098263ffffffff61140616565b604051600160a060020a038216907f90eabbc0c667db2a5029ed6bc0f5fe9f356d11684a4ca9fcfaec0e53f12b9c8e90600090a250565b600160a060020a03811615156111d957600080fd5b60008054604051600160a060020a03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a36000805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b61125260098263ffffffff61145216565b604051600160a060020a038216907f86e57fd2b90329052917118de7c3f521f400d439b9650deaa906a25b08b9456090600090a250565b600160a060020a03831660009081526005602090815260408083203384529091528120548211156112b957600080fd5b600160a060020a03841660009081526005602090815260408083203384529091529020546112ed908363ffffffff6113ef16565b600160a060020a038516600090815260056020908152604080832033845290915290205561131c8484846114a9565b5060019392505050565b60008282018381101561133857600080fd5b8091505b5092915050565b600160a060020a038216151561135857600080fd5b60065461136b908263ffffffff61132616565b600655600160a060020a038216600090815260046020526040902054611397908263ffffffff61132616565b600160a060020a03831660008181526004602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b600080838311156113ff57600080fd5b5050900390565b600160a060020a038116151561141b57600080fd5b6114258282610f2b565b151561143057600080fd5b600160a060020a0316600090815260209190915260409020805460ff19169055565b600160a060020a038116151561146757600080fd5b6114718282610f2b565b1561147b57600080fd5b600160a060020a0316600090815260209190915260409020805460ff19166001179055565b60006108b63384845b600160a060020a0383166000908152600460205260409020548111156114ce57600080fd5b600160a060020a03821615156114e357600080fd5b600160a060020a03831660009081526004602052604090205461150c908263ffffffff6113ef16565b600160a060020a038085166000908152600460205260408082209390935590841681522054611541908263ffffffff61132616565b600160a060020a0380841660008181526004602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b6000808315156115b0576000915061133c565b508282028284828115156115c057fe5b041461133857600080fd00a165627a7a72305820f12ac6b0706605cedff8ad94f6f3be360ad02ea8f9d2a9a4b0c53a8d0212d4840029

Swarm Source

bzzr://f12ac6b0706605cedff8ad94f6f3be360ad02ea8f9d2a9a4b0c53a8d0212d484
Block Age Transaction Difficulty GasUsed Reward
Block Age Uncle Number Difficulty GasUsed Reward
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.