ETH Price: $2,967.03 (+3.56%)
Gas: 1 Gwei

Token

Bankorus Token (BKTS)
 

Overview

Max Total Supply

34,765,465.79463284 BKTS

Holders

312

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 8 Decimals)

Balance
9,996.72043011 BKTS

Value
$0.00
0x9d3e21eab3758c55002aead8305e7d6ae154e231
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
BankorusToken

Compiler Version
v0.5.8+commit.23d335f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2019-06-14
*/

pragma solidity ^0.5.2;

/**
 * @title ERC20 interface
 * @dev see https://eips.ethereum.org/EIPS/eip-20
 */
interface IERC20 {
    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);

    function totalSupply() external view returns (uint256);

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

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

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

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

// File: openzeppelin-solidity/contracts/math/SafeMath.sol

pragma solidity ^0.5.2;

/**
 * @title SafeMath
 * @dev Unsigned math operations with safety checks that revert on error
 */
library SafeMath {
    /**
     * @dev Multiplies two unsigned integers, 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 unsigned integers truncating the quotient, reverts on division by zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        // Solidity only automatically asserts when dividing by 0
        require(b > 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 unsigned integers, 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 unsigned integers, 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 unsigned integers 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;
    }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20.sol

pragma solidity ^0.5.2;



/**
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * https://eips.ethereum.org/EIPS/eip-20
 * Originally based on code by FirstBlood:
 * https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 *
 * This implementation emits additional Approval events, allowing applications to reconstruct the allowance status for
 * all accounts just by listening to said events. Note that this isn't required by the specification, and other
 * compliant implementations may not do it.
 */
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 A 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 to 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) {
        _approve(msg.sender, spender, value);
        return true;
    }

    /**
     * @dev Transfer tokens from one address to another.
     * Note that while this function emits an Approval event, this is not required as per the specification,
     * and other compliant implementations may not emit the event.
     * @param from address The address which you want to send tokens from
     * @param to address The address which you want to transfer to
     * @param value uint256 the amount of tokens to be transferred
     */
    function transferFrom(address from, address to, uint256 value) public returns (bool) {
        _transfer(from, to, value);
        _approve(from, msg.sender, _allowed[from][msg.sender].sub(value));
        return true;
    }

    /**
     * @dev Increase the amount of tokens that an owner allowed to a spender.
     * approve should be called when _allowed[msg.sender][spender] == 0. To increment
     * allowed value is better to use this function to avoid 2 calls (and wait until
     * the first transaction is mined)
     * From MonolithDAO Token.sol
     * Emits an Approval event.
     * @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) {
        _approve(msg.sender, spender, _allowed[msg.sender][spender].add(addedValue));
        return true;
    }

    /**
     * @dev Decrease the amount of tokens that an owner allowed to a spender.
     * approve should be called when _allowed[msg.sender][spender] == 0. To decrement
     * allowed value is better to use this function to avoid 2 calls (and wait until
     * the first transaction is mined)
     * From MonolithDAO Token.sol
     * Emits an Approval event.
     * @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) {
        _approve(msg.sender, spender, _allowed[msg.sender][spender].sub(subtractedValue));
        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(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 != address(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 != address(0));

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

    /**
     * @dev Approve an address to spend another addresses' tokens.
     * @param owner The address that owns the tokens.
     * @param spender The address that will spend the tokens.
     * @param value The number of tokens that can be spent.
     */
    function _approve(address owner, address spender, uint256 value) internal {
        require(spender != address(0));
        require(owner != address(0));

        _allowed[owner][spender] = value;
        emit Approval(owner, spender, 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.
     * Emits an Approval event (reflecting the reduced allowance).
     * @param account The account whose tokens will be burnt.
     * @param value The amount that will be burnt.
     */
    function _burnFrom(address account, uint256 value) internal {
        _burn(account, value);
        _approve(account, msg.sender, _allowed[account][msg.sender].sub(value));
    }
}

// File: openzeppelin-solidity/contracts/access/Roles.sol

pragma solidity ^0.5.2;

/**
 * @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];
    }
}

// File: openzeppelin-solidity/contracts/access/roles/PauserRole.sol

pragma solidity ^0.5.2;


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

// File: openzeppelin-solidity/contracts/lifecycle/Pausable.sol

pragma solidity ^0.5.2;


/**
 * @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);
    }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Pausable.sol

pragma solidity ^0.5.2;



/**
 * @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);
    }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Detailed.sol

pragma solidity ^0.5.2;


/**
 * @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 memory name, string memory symbol, uint8 decimals) public {
        _name = name;
        _symbol = symbol;
        _decimals = decimals;
    }

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

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

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

// File: openzeppelin-solidity/contracts/access/roles/MinterRole.sol

pragma solidity ^0.5.2;


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

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Mintable.sol

pragma solidity ^0.5.2;



/**
 * @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;
    }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Capped.sol

pragma solidity ^0.5.2;


/**
 * @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);
    }
}

// File: contracts/BankorusToken.sol

pragma solidity ^0.5.2;





contract BankorusToken is ERC20Capped, ERC20Pausable, ERC20Detailed {
    event PausedAddress(address pausedAddress, address acount);
    event UnpausedAddress(address unpausedAddress, address acount);

    event ApproveBurnEvent(address owner, address burner, uint256 amount);

    mapping(address => bool) _pausedAddress;

    mapping(address => mapping(address => uint256)) _burnApproved;

    constructor()
    ERC20Capped(3500000000000000)
    ERC20Pausable()
    ERC20Detailed("Bankorus Token", "BKTS", 8)
    public {}

    /**
     * @dev Modifier to make a function callable only when the account is not paused.
     */
    modifier whenAddressIsNotPuased(address to) {
        require(!_pausedAddress[msg.sender]);
        require(!_pausedAddress[to]);
        _;
    }

    /**
     * @dev true if the account is paused, false otherwise.
     */
    function addressPaused(address account) public view returns (bool) {
        return _pausedAddress[account];
    }

     /**
     * @dev called by the owner to pause an address, returns to normal state
     */
    function pauseAddress(address pausedAddress) public onlyPauser whenNotPaused{
        _pausedAddress[pausedAddress] = true;
        emit PausedAddress(pausedAddress, msg.sender);
    }

    /**
     * @dev called by the owner to unpause an address, returns to normal state
     */
    function unpauseAddress(address unpausedAddress) public onlyPauser whenNotPaused {
        _pausedAddress[unpausedAddress] = false;
        emit UnpausedAddress(unpausedAddress, msg.sender);
    }

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

    function transferFrom(address from, address to, uint256 value) public whenAddressIsNotPuased(to) returns (bool) {
        require(!_pausedAddress[from]);
        return super.transferFrom(from, to, value);
    }

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

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

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

    /**
     * @dev Destoys `amount` tokens from the caller.
     *
     * See `ERC20._burn`.
     */
    function burn(uint256 amount) public whenNotPaused {
        _burn(msg.sender, amount);
    }


    /**
     * @dev allow account to burn `amount` tokens 
     * Requirements:
     * - `burner` cannot be zero address
     * - 
     */
    function approveBurn(address burner, uint256 amount) public returns (bool) {
        require(burner != address(0));
        require(amount > 0);
        _burnApproved[msg.sender][burner] = amount;
    }

    /**
     * @dev See `ERC20._burnFrom`.
     */
    function burnFrom(address from, uint256 amount) public whenNotPaused {
        require(from != address(0));
        require(amount > 0);
        _burnApproved[from][msg.sender] = _burnApproved[from][msg.sender].sub(amount);
        _burnFrom(from, amount);
    }

    /**
     * @dev batchMint
     */

    function batchMint(address[] memory accounts, uint256[] memory amounts) public whenNotPaused onlyMinter {
        require(accounts.length == amounts.length);
        require(accounts.length < 50);

        for (uint i = 0; i < accounts.length; i++) {
            mint(accounts[i], amounts[i]);
        }
        
    }
}

Contract Security Audit

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":false,"inputs":[{"name":"burner","type":"address"},{"name":"amount","type":"uint256"}],"name":"approveBurn","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":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"addressPaused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","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":"amount","type":"uint256"}],"name":"burn","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":"accounts","type":"address[]"},{"name":"amounts","type":"uint256[]"}],"name":"batchMint","outputs":[],"payable":false,"stateMutability":"nonpayable","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":"pausedAddress","type":"address"}],"name":"pauseAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","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":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":"spender","type":"address"},{"name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"name":"","type":"bool"}],"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":"unpausedAddress","type":"address"}],"name":"unpauseAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"name":"pausedAddress","type":"address"},{"indexed":false,"name":"acount","type":"address"}],"name":"PausedAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"unpausedAddress","type":"address"},{"indexed":false,"name":"acount","type":"address"}],"name":"UnpausedAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"owner","type":"address"},{"indexed":false,"name":"burner","type":"address"},{"indexed":false,"name":"amount","type":"uint256"}],"name":"ApproveBurnEvent","type":"event"},{"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":"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"}]

60806040523480156200001157600080fd5b506040518060400160405280600e81526020017f42616e6b6f72757320546f6b656e0000000000000000000000000000000000008152506040518060400160405280600481526020017f424b5453000000000000000000000000000000000000000000000000000000008152506008660c6f3b40b6c00062000099336200010f60201b60201c565b60008111620000a757600080fd5b600455620000bc3362000161602090811b901c565b6006805460ff191690558251620000db9060079060208601906200023f565b508151620000f19060089060208501906200023f565b506009805460ff191660ff9290921691909117905550620002e49050565b6200012a816003620001b360201b620013521790919060201c565b6040516001600160a01b038216907f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f690600090a250565b6200017c816005620001b360201b620013521790919060201c565b6040516001600160a01b038216907f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f890600090a250565b6001600160a01b038116620001c757600080fd5b620001d982826200020960201b60201c565b15620001e457600080fd5b6001600160a01b0316600090815260209190915260409020805460ff19166001179055565b60006001600160a01b0382166200021f57600080fd5b506001600160a01b03166000908152602091909152604090205460ff1690565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106200028257805160ff1916838001178555620002b2565b82800160010185558215620002b2579182015b82811115620002b257825182559160200191906001019062000295565b50620002c0929150620002c4565b5090565b620002e191905b80821115620002c05760008155600101620002cb565b90565b6114da80620002f46000396000f3fe608060405234801561001057600080fd5b50600436106101cf5760003560e01c8063685731071161010457806395d89b41116100a2578063a9059cbb11610071578063a9059cbb1461063d578063aa271e1a14610669578063dd62ed3e1461068f578063f5822027146106bd576101cf565b806395d89b41146105db578063983b2d56146105e35780639865027514610609578063a457c2d714610611576101cf565b806377df472c116100de57806377df472c1461055b57806379cc67901461058157806382dc1ec4146105ad5780638456cb59146105d3576101cf565b806368573107146104065780636ef8d66d1461052d57806370a0823114610535576101cf565b8063395093511161017157806340c10f191161014b57806340c10f191461038f57806342966c68146103bb57806346fbf68e146103d85780635c975abb146103fe576101cf565b8063395093511461033357806339abaf8b1461035f5780633f4ba83a14610385576101cf565b806318160ddd116101ad57806318160ddd146102bd57806323b872dd146102d7578063313ce5671461030d578063355274ea1461032b576101cf565b806306fdde03146101d4578063095ea7b3146102515780630cfa031814610291575b600080fd5b6101dc6106e3565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102165781810151838201526020016101fe565b50505050905090810190601f1680156102435780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61027d6004803603604081101561026757600080fd5b506001600160a01b038135169060200135610779565b604080519115158252519081900360200190f35b61027d600480360360408110156102a757600080fd5b506001600160a01b0381351690602001356107d0565b6102c561081d565b60408051918252519081900360200190f35b61027d600480360360608110156102ed57600080fd5b506001600160a01b03813581169160208101359091169060400135610823565b6103156108a2565b6040805160ff9092168252519081900360200190f35b6102c56108ab565b61027d6004803603604081101561034957600080fd5b506001600160a01b0381351690602001356108b1565b61027d6004803603602081101561037557600080fd5b50356001600160a01b0316610900565b61038d61091e565b005b61027d600480360360408110156103a557600080fd5b506001600160a01b03813516906020013561097e565b61038d600480360360208110156103d157600080fd5b50356109a5565b61027d600480360360208110156103ee57600080fd5b50356001600160a01b03166109c2565b61027d6109db565b61038d6004803603604081101561041c57600080fd5b81019060208101813564010000000081111561043757600080fd5b82018360208201111561044957600080fd5b8035906020019184602083028401116401000000008311171561046b57600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092959493602081019350359150506401000000008111156104bb57600080fd5b8201836020820111156104cd57600080fd5b803590602001918460208302840111640100000000831117156104ef57600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295506109e4945050505050565b61038d610a6c565b6102c56004803603602081101561054b57600080fd5b50356001600160a01b0316610a77565b61038d6004803603602081101561057157600080fd5b50356001600160a01b0316610a92565b61038d6004803603604081101561059757600080fd5b506001600160a01b038135169060200135610b14565b61038d600480360360208110156105c357600080fd5b50356001600160a01b0316610baa565b61038d610bc5565b6101dc610c29565b61038d600480360360208110156105f957600080fd5b50356001600160a01b0316610c8a565b61038d610ca5565b61027d6004803603604081101561062757600080fd5b506001600160a01b038135169060200135610cae565b61027d6004803603604081101561065357600080fd5b506001600160a01b038135169060200135610cfd565b61027d6004803603602081101561067f57600080fd5b50356001600160a01b0316610d4c565b6102c5600480360360408110156106a557600080fd5b506001600160a01b0381358116916020013516610d5f565b61038d600480360360208110156106d357600080fd5b50356001600160a01b0316610d8a565b60078054604080516020601f600260001961010060018816150201909516949094049384018190048102820181019092528281526060939092909183018282801561076f5780601f106107445761010080835404028352916020019161076f565b820191906000526020600020905b81548152906001019060200180831161075257829003601f168201915b5050505050905090565b336000908152600a6020526040812054839060ff161561079857600080fd5b6001600160a01b0381166000908152600a602052604090205460ff16156107be57600080fd5b6107c88484610e09565b949350505050565b60006001600160a01b0383166107e557600080fd5b600082116107f257600080fd5b336000908152600b602090815260408083206001600160a01b03969096168352949052929092205590565b60025490565b336000908152600a6020526040812054839060ff161561084257600080fd5b6001600160a01b0381166000908152600a602052604090205460ff161561086857600080fd5b6001600160a01b0385166000908152600a602052604090205460ff161561088e57600080fd5b610899858585610e2d565b95945050505050565b60095460ff1690565b60045490565b336000908152600a6020526040812054839060ff16156108d057600080fd5b6001600160a01b0381166000908152600a602052604090205460ff16156108f657600080fd5b6107c88484610e4b565b6001600160a01b03166000908152600a602052604090205460ff1690565b610927336109c2565b61093057600080fd5b60065460ff1661093f57600080fd5b6006805460ff191690556040805133815290517f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa9181900360200190a1565b600061098933610d4c565b61099257600080fd5b61099c8383610e68565b50600192915050565b60065460ff16156109b557600080fd5b6109bf3382610e98565b50565b60006109d560058363ffffffff610f3f16565b92915050565b60065460ff1690565b60065460ff16156109f457600080fd5b6109fd33610d4c565b610a0657600080fd5b8051825114610a1457600080fd5b6032825110610a2257600080fd5b60005b8251811015610a6757610a5e838281518110610a3d57fe5b6020026020010151838381518110610a5157fe5b602002602001015161097e565b50600101610a25565b505050565b610a7533610f74565b565b6001600160a01b031660009081526020819052604090205490565b610a9b336109c2565b610aa457600080fd5b60065460ff1615610ab457600080fd5b6001600160a01b0381166000818152600a6020908152604091829020805460ff191660011790558151928352339083015280517fddad90ed37d718f4d9f4e52ebf8b63bab7e680b0a32ac8e43e83527a21b795fc9281900390910190a150565b60065460ff1615610b2457600080fd5b6001600160a01b038216610b3757600080fd5b60008111610b4457600080fd5b6001600160a01b0382166000908152600b60209081526040808320338452909152902054610b78908263ffffffff610fbc16565b6001600160a01b0383166000908152600b60209081526040808320338452909152902055610ba68282610fd1565b5050565b610bb3336109c2565b610bbc57600080fd5b6109bf8161101b565b610bce336109c2565b610bd757600080fd5b60065460ff1615610be757600080fd5b6006805460ff191660011790556040805133815290517f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2589181900360200190a1565b60088054604080516020601f600260001961010060018816150201909516949094049384018190048102820181019092528281526060939092909183018282801561076f5780601f106107445761010080835404028352916020019161076f565b610c9333610d4c565b610c9c57600080fd5b6109bf81611063565b610a75336110ab565b336000908152600a6020526040812054839060ff1615610ccd57600080fd5b6001600160a01b0381166000908152600a602052604090205460ff1615610cf357600080fd5b6107c884846110f3565b336000908152600a6020526040812054839060ff1615610d1c57600080fd5b6001600160a01b0381166000908152600a602052604090205460ff1615610d4257600080fd5b6107c88484611110565b60006109d560038363ffffffff610f3f16565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610d93336109c2565b610d9c57600080fd5b60065460ff1615610dac57600080fd5b6001600160a01b0381166000818152600a6020908152604091829020805460ff191690558151928352339083015280517f01378564ef76ac1304ed3bf483576a084337eaca6e22c261f9624588fad573989281900390910190a150565b60065460009060ff1615610e1c57600080fd5b610e26838361112d565b9392505050565b60065460009060ff1615610e4057600080fd5b6107c884848461113a565b60065460009060ff1615610e5e57600080fd5b610e26838361118c565b600454610e8382610e7761081d565b9063ffffffff6111c816565b1115610e8e57600080fd5b610ba682826111da565b6001600160a01b038216610eab57600080fd5b600254610ebe908263ffffffff610fbc16565b6002556001600160a01b038216600090815260208190526040902054610eea908263ffffffff610fbc16565b6001600160a01b038316600081815260208181526040808320949094558351858152935191937fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929081900390910190a35050565b60006001600160a01b038216610f5457600080fd5b506001600160a01b03166000908152602091909152604090205460ff1690565b610f8560058263ffffffff61128216565b6040516001600160a01b038216907fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e90600090a250565b600082821115610fcb57600080fd5b50900390565b610fdb8282610e98565b6001600160a01b038216600090815260016020908152604080832033808552925290912054610ba6918491611016908563ffffffff610fbc16565b6112ca565b61102c60058263ffffffff61135216565b6040516001600160a01b038216907f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f890600090a250565b61107460038263ffffffff61135216565b6040516001600160a01b038216907f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f690600090a250565b6110bc60038263ffffffff61128216565b6040516001600160a01b038216907fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb6669290600090a250565b60065460009060ff161561110657600080fd5b610e26838361139e565b60065460009060ff161561112357600080fd5b610e2683836113da565b600061099c3384846112ca565b60006111478484846113e3565b6001600160a01b038416600090815260016020908152604080832033808552925290912054611182918691611016908663ffffffff610fbc16565b5060019392505050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161099c918590611016908663ffffffff6111c816565b600082820183811015610e2657600080fd5b6001600160a01b0382166111ed57600080fd5b600254611200908263ffffffff6111c816565b6002556001600160a01b03821660009081526020819052604090205461122c908263ffffffff6111c816565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6001600160a01b03811661129557600080fd5b61129f8282610f3f565b6112a857600080fd5b6001600160a01b0316600090815260209190915260409020805460ff19169055565b6001600160a01b0382166112dd57600080fd5b6001600160a01b0383166112f057600080fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b03811661136557600080fd5b61136f8282610f3f565b1561137957600080fd5b6001600160a01b0316600090815260209190915260409020805460ff19166001179055565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161099c918590611016908663ffffffff610fbc16565b600061099c3384845b6001600160a01b0382166113f657600080fd5b6001600160a01b03831660009081526020819052604090205461141f908263ffffffff610fbc16565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611454908263ffffffff6111c816565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a350505056fea165627a7a72305820b718fdaf5b1c14dc308681e2f95ad97b42db0cac7934bf9d0a6ba2d09e424fae0029

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101cf5760003560e01c8063685731071161010457806395d89b41116100a2578063a9059cbb11610071578063a9059cbb1461063d578063aa271e1a14610669578063dd62ed3e1461068f578063f5822027146106bd576101cf565b806395d89b41146105db578063983b2d56146105e35780639865027514610609578063a457c2d714610611576101cf565b806377df472c116100de57806377df472c1461055b57806379cc67901461058157806382dc1ec4146105ad5780638456cb59146105d3576101cf565b806368573107146104065780636ef8d66d1461052d57806370a0823114610535576101cf565b8063395093511161017157806340c10f191161014b57806340c10f191461038f57806342966c68146103bb57806346fbf68e146103d85780635c975abb146103fe576101cf565b8063395093511461033357806339abaf8b1461035f5780633f4ba83a14610385576101cf565b806318160ddd116101ad57806318160ddd146102bd57806323b872dd146102d7578063313ce5671461030d578063355274ea1461032b576101cf565b806306fdde03146101d4578063095ea7b3146102515780630cfa031814610291575b600080fd5b6101dc6106e3565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102165781810151838201526020016101fe565b50505050905090810190601f1680156102435780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61027d6004803603604081101561026757600080fd5b506001600160a01b038135169060200135610779565b604080519115158252519081900360200190f35b61027d600480360360408110156102a757600080fd5b506001600160a01b0381351690602001356107d0565b6102c561081d565b60408051918252519081900360200190f35b61027d600480360360608110156102ed57600080fd5b506001600160a01b03813581169160208101359091169060400135610823565b6103156108a2565b6040805160ff9092168252519081900360200190f35b6102c56108ab565b61027d6004803603604081101561034957600080fd5b506001600160a01b0381351690602001356108b1565b61027d6004803603602081101561037557600080fd5b50356001600160a01b0316610900565b61038d61091e565b005b61027d600480360360408110156103a557600080fd5b506001600160a01b03813516906020013561097e565b61038d600480360360208110156103d157600080fd5b50356109a5565b61027d600480360360208110156103ee57600080fd5b50356001600160a01b03166109c2565b61027d6109db565b61038d6004803603604081101561041c57600080fd5b81019060208101813564010000000081111561043757600080fd5b82018360208201111561044957600080fd5b8035906020019184602083028401116401000000008311171561046b57600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092959493602081019350359150506401000000008111156104bb57600080fd5b8201836020820111156104cd57600080fd5b803590602001918460208302840111640100000000831117156104ef57600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295506109e4945050505050565b61038d610a6c565b6102c56004803603602081101561054b57600080fd5b50356001600160a01b0316610a77565b61038d6004803603602081101561057157600080fd5b50356001600160a01b0316610a92565b61038d6004803603604081101561059757600080fd5b506001600160a01b038135169060200135610b14565b61038d600480360360208110156105c357600080fd5b50356001600160a01b0316610baa565b61038d610bc5565b6101dc610c29565b61038d600480360360208110156105f957600080fd5b50356001600160a01b0316610c8a565b61038d610ca5565b61027d6004803603604081101561062757600080fd5b506001600160a01b038135169060200135610cae565b61027d6004803603604081101561065357600080fd5b506001600160a01b038135169060200135610cfd565b61027d6004803603602081101561067f57600080fd5b50356001600160a01b0316610d4c565b6102c5600480360360408110156106a557600080fd5b506001600160a01b0381358116916020013516610d5f565b61038d600480360360208110156106d357600080fd5b50356001600160a01b0316610d8a565b60078054604080516020601f600260001961010060018816150201909516949094049384018190048102820181019092528281526060939092909183018282801561076f5780601f106107445761010080835404028352916020019161076f565b820191906000526020600020905b81548152906001019060200180831161075257829003601f168201915b5050505050905090565b336000908152600a6020526040812054839060ff161561079857600080fd5b6001600160a01b0381166000908152600a602052604090205460ff16156107be57600080fd5b6107c88484610e09565b949350505050565b60006001600160a01b0383166107e557600080fd5b600082116107f257600080fd5b336000908152600b602090815260408083206001600160a01b03969096168352949052929092205590565b60025490565b336000908152600a6020526040812054839060ff161561084257600080fd5b6001600160a01b0381166000908152600a602052604090205460ff161561086857600080fd5b6001600160a01b0385166000908152600a602052604090205460ff161561088e57600080fd5b610899858585610e2d565b95945050505050565b60095460ff1690565b60045490565b336000908152600a6020526040812054839060ff16156108d057600080fd5b6001600160a01b0381166000908152600a602052604090205460ff16156108f657600080fd5b6107c88484610e4b565b6001600160a01b03166000908152600a602052604090205460ff1690565b610927336109c2565b61093057600080fd5b60065460ff1661093f57600080fd5b6006805460ff191690556040805133815290517f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa9181900360200190a1565b600061098933610d4c565b61099257600080fd5b61099c8383610e68565b50600192915050565b60065460ff16156109b557600080fd5b6109bf3382610e98565b50565b60006109d560058363ffffffff610f3f16565b92915050565b60065460ff1690565b60065460ff16156109f457600080fd5b6109fd33610d4c565b610a0657600080fd5b8051825114610a1457600080fd5b6032825110610a2257600080fd5b60005b8251811015610a6757610a5e838281518110610a3d57fe5b6020026020010151838381518110610a5157fe5b602002602001015161097e565b50600101610a25565b505050565b610a7533610f74565b565b6001600160a01b031660009081526020819052604090205490565b610a9b336109c2565b610aa457600080fd5b60065460ff1615610ab457600080fd5b6001600160a01b0381166000818152600a6020908152604091829020805460ff191660011790558151928352339083015280517fddad90ed37d718f4d9f4e52ebf8b63bab7e680b0a32ac8e43e83527a21b795fc9281900390910190a150565b60065460ff1615610b2457600080fd5b6001600160a01b038216610b3757600080fd5b60008111610b4457600080fd5b6001600160a01b0382166000908152600b60209081526040808320338452909152902054610b78908263ffffffff610fbc16565b6001600160a01b0383166000908152600b60209081526040808320338452909152902055610ba68282610fd1565b5050565b610bb3336109c2565b610bbc57600080fd5b6109bf8161101b565b610bce336109c2565b610bd757600080fd5b60065460ff1615610be757600080fd5b6006805460ff191660011790556040805133815290517f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2589181900360200190a1565b60088054604080516020601f600260001961010060018816150201909516949094049384018190048102820181019092528281526060939092909183018282801561076f5780601f106107445761010080835404028352916020019161076f565b610c9333610d4c565b610c9c57600080fd5b6109bf81611063565b610a75336110ab565b336000908152600a6020526040812054839060ff1615610ccd57600080fd5b6001600160a01b0381166000908152600a602052604090205460ff1615610cf357600080fd5b6107c884846110f3565b336000908152600a6020526040812054839060ff1615610d1c57600080fd5b6001600160a01b0381166000908152600a602052604090205460ff1615610d4257600080fd5b6107c88484611110565b60006109d560038363ffffffff610f3f16565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610d93336109c2565b610d9c57600080fd5b60065460ff1615610dac57600080fd5b6001600160a01b0381166000818152600a6020908152604091829020805460ff191690558151928352339083015280517f01378564ef76ac1304ed3bf483576a084337eaca6e22c261f9624588fad573989281900390910190a150565b60065460009060ff1615610e1c57600080fd5b610e26838361112d565b9392505050565b60065460009060ff1615610e4057600080fd5b6107c884848461113a565b60065460009060ff1615610e5e57600080fd5b610e26838361118c565b600454610e8382610e7761081d565b9063ffffffff6111c816565b1115610e8e57600080fd5b610ba682826111da565b6001600160a01b038216610eab57600080fd5b600254610ebe908263ffffffff610fbc16565b6002556001600160a01b038216600090815260208190526040902054610eea908263ffffffff610fbc16565b6001600160a01b038316600081815260208181526040808320949094558351858152935191937fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929081900390910190a35050565b60006001600160a01b038216610f5457600080fd5b506001600160a01b03166000908152602091909152604090205460ff1690565b610f8560058263ffffffff61128216565b6040516001600160a01b038216907fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e90600090a250565b600082821115610fcb57600080fd5b50900390565b610fdb8282610e98565b6001600160a01b038216600090815260016020908152604080832033808552925290912054610ba6918491611016908563ffffffff610fbc16565b6112ca565b61102c60058263ffffffff61135216565b6040516001600160a01b038216907f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f890600090a250565b61107460038263ffffffff61135216565b6040516001600160a01b038216907f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f690600090a250565b6110bc60038263ffffffff61128216565b6040516001600160a01b038216907fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb6669290600090a250565b60065460009060ff161561110657600080fd5b610e26838361139e565b60065460009060ff161561112357600080fd5b610e2683836113da565b600061099c3384846112ca565b60006111478484846113e3565b6001600160a01b038416600090815260016020908152604080832033808552925290912054611182918691611016908663ffffffff610fbc16565b5060019392505050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161099c918590611016908663ffffffff6111c816565b600082820183811015610e2657600080fd5b6001600160a01b0382166111ed57600080fd5b600254611200908263ffffffff6111c816565b6002556001600160a01b03821660009081526020819052604090205461122c908263ffffffff6111c816565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6001600160a01b03811661129557600080fd5b61129f8282610f3f565b6112a857600080fd5b6001600160a01b0316600090815260209190915260409020805460ff19169055565b6001600160a01b0382166112dd57600080fd5b6001600160a01b0383166112f057600080fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b03811661136557600080fd5b61136f8282610f3f565b1561137957600080fd5b6001600160a01b0316600090815260209190915260409020805460ff19166001179055565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161099c918590611016908663ffffffff610fbc16565b600061099c3384845b6001600160a01b0382166113f657600080fd5b6001600160a01b03831660009081526020819052604090205461141f908263ffffffff610fbc16565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611454908263ffffffff6111c816565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a350505056fea165627a7a72305820b718fdaf5b1c14dc308681e2f95ad97b42db0cac7934bf9d0a6ba2d09e424fae0029

Deployed Bytecode Sourcemap

18639:3819:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;18639:3819:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15863:83;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;15863:83:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20624:158;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20624:158:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;21543:206;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;21543:206:0;;;;;;;;:::i;3729:91::-;;;:::i;:::-;;;;;;;;;;;;;;;;20402:214;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20402:214:0;;;;;;;;;;;;;;;;;:::i;16179:83::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;18320:75;;;:::i;20790:185::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20790:185:0;;;;;;;;:::i;19528:116::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19528:116:0;-1:-1:-1;;;;;19528:116:0;;:::i;13966:118::-;;;:::i;:::-;;17769:131;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;17769:131:0;;;;;;;;:::i;21293:95::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;21293:95:0;;:::i;12144:109::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12144:109:0;-1:-1:-1;;;;;12144:109:0;;:::i;13219:78::-;;;:::i;22129:326::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;22129:326:0;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;22129:326:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;22129:326:0;;;;;;101:9:-1;95:2;81:12;77:21;67:8;63:36;60:51;39:11;25:12;22:29;11:108;8:2;;;132:1;129;122:12;8:2;22129:326:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;22129:326:0;;;;;;;;-1:-1:-1;22129:326:0;;-1:-1:-1;;21:11;5:28;;2:2;;;46:1;43;36:12;2:2;22129:326:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;22129:326:0;;;;;;101:9:-1;95:2;81:12;77:21;67:8;63:36;60:51;39:11;25:12;22:29;11:108;8:2;;;132:1;129;122:12;8:2;22129:326:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;22129:326:0;;-1:-1:-1;22129:326:0;;-1:-1:-1;;;;;22129:326:0:i;12361:77::-;;;:::i;4039:106::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;4039:106:0;-1:-1:-1;;;;;4039:106:0;;:::i;19749:187::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19749:187:0;-1:-1:-1;;;;;19749:187:0;;:::i;21811:267::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;21811:267:0;;;;;;;;:::i;12261:92::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12261:92:0;-1:-1:-1;;;;;12261:92:0;;:::i;13755:116::-;;;:::i;16013:87::-;;;:::i;16850:92::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16850:92:0;-1:-1:-1;;;;;16850:92:0;;:::i;16950:77::-;;;:::i;20983:195::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20983:195:0;;;;;;;;:::i;20249:145::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20249:145:0;;;;;;;;:::i;16733:109::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16733:109:0;-1:-1:-1;;;;;16733:109:0;;:::i;4484:131::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;4484:131:0;;;;;;;;;;:::i;20042:199::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;20042:199:0;-1:-1:-1;;;;;20042:199:0;;:::i;15863:83::-;15933:5;15926:12;;;;;;;;-1:-1:-1;;15926:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15900:13;;15926:12;;15933:5;;15926:12;;15933:5;15926:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15863:83;:::o;20624:158::-;19370:10;20721:4;19355:26;;;:14;:26;;;;;;20703:7;;19355:26;;19354:27;19346:36;;;;;;-1:-1:-1;;;;;19402:18:0;;;;;;:14;:18;;;;;;;;19401:19;19393:28;;;;;;20745:29;20759:7;20768:5;20745:13;:29::i;:::-;20738:36;20624:158;-1:-1:-1;;;;20624:158:0:o;21543:206::-;21612:4;-1:-1:-1;;;;;21637:20:0;;21629:29;;;;;;21686:1;21677:6;:10;21669:19;;;;;;21713:10;21699:25;;;;:13;:25;;;;;;;;-1:-1:-1;;;;;21699:33:0;;;;;;;;;;;;;:42;21543:206;:::o;3729:91::-;3800:12;;3729:91;:::o;20402:214::-;19370:10;20508:4;19355:26;;;:14;:26;;;;;;20495:2;;19355:26;;19354:27;19346:36;;;;;;-1:-1:-1;;;;;19402:18:0;;;;;;:14;:18;;;;;;;;19401:19;19393:28;;;;;;-1:-1:-1;;;;;20534:20:0;;;;;;:14;:20;;;;;;;;20533:21;20525:30;;;;;;20573:35;20592:4;20598:2;20602:5;20573:18;:35::i;:::-;20566:42;20402:214;-1:-1:-1;;;;;20402:214:0:o;16179:83::-;16245:9;;;;16179:83;:::o;18320:75::-;18383:4;;18320:75;:::o;20790:185::-;19370:10;20899:4;19355:26;;;:14;:26;;;;;;20881:7;;19355:26;;19354:27;19346:36;;;;;;-1:-1:-1;;;;;19402:18:0;;;;;;:14;:18;;;;;;;;19401:19;19393:28;;;;;;20923:44;20947:7;20956:10;20923:23;:44::i;19528:116::-;-1:-1:-1;;;;;19613:23:0;19589:4;19613:23;;;:14;:23;;;;;;;;;19528:116::o;13966:118::-;12095:20;12104:10;12095:8;:20::i;:::-;12087:29;;;;;;13635:7;;;;13627:16;;;;;;14025:7;:15;;-1:-1:-1;;14025:15:0;;;14056:20;;;14065:10;14056:20;;;;;;;;;;;;;13966:118::o;17769:131::-;17837:4;16684:20;16693:10;16684:8;:20::i;:::-;16676:29;;;;;;17854:16;17860:2;17864:5;17854;:16::i;:::-;-1:-1:-1;17888:4:0;17769:131;;;;:::o;21293:95::-;13456:7;;;;13455:8;13447:17;;;;;;21355:25;21361:10;21373:6;21355:5;:25::i;:::-;21293:95;:::o;12144:109::-;12200:4;12224:21;:8;12237:7;12224:21;:12;:21;:::i;:::-;12217:28;12144:109;-1:-1:-1;;12144:109:0:o;13219:78::-;13282:7;;;;13219:78;:::o;22129:326::-;13456:7;;;;13455:8;13447:17;;;;;;16684:20;16693:10;16684:8;:20::i;:::-;16676:29;;;;;;22271:7;:14;22252:8;:15;:33;22244:42;;;;;;22323:2;22305:8;:15;:20;22297:29;;;;;;22344:6;22339:99;22360:8;:15;22356:1;:19;22339:99;;;22397:29;22402:8;22411:1;22402:11;;;;;;;;;;;;;;22415:7;22423:1;22415:10;;;;;;;;;;;;;;22397:4;:29::i;:::-;-1:-1:-1;22377:3:0;;22339:99;;;;22129:326;;:::o;12361:77::-;12405:25;12419:10;12405:13;:25::i;:::-;12361:77::o;4039:106::-;-1:-1:-1;;;;;4121:16:0;4094:7;4121:16;;;;;;;;;;;;4039:106::o;19749:187::-;12095:20;12104:10;12095:8;:20::i;:::-;12087:29;;;;;;13456:7;;;;13455:8;13447:17;;;;;;-1:-1:-1;;;;;19836:29:0;;;;;;:14;:29;;;;;;;;;:36;;-1:-1:-1;;19836:36:0;19868:4;19836:36;;;19888:40;;;;;19917:10;19888:40;;;;;;;;;;;;;;;;19749:187;:::o;21811:267::-;13456:7;;;;13455:8;13447:17;;;;;;-1:-1:-1;;;;;21899:18:0;;21891:27;;;;;;21946:1;21937:6;:10;21929:19;;;;;;-1:-1:-1;;;;;21993:19:0;;;;;;:13;:19;;;;;;;;22013:10;21993:31;;;;;;;;:43;;22029:6;21993:43;:35;:43;:::i;:::-;-1:-1:-1;;;;;21959:19:0;;;;;;:13;:19;;;;;;;;21979:10;21959:31;;;;;;;:77;22047:23;21973:4;22063:6;22047:9;:23::i;:::-;21811:267;;:::o;12261:92::-;12095:20;12104:10;12095:8;:20::i;:::-;12087:29;;;;;;12326:19;12337:7;12326:10;:19::i;13755:116::-;12095:20;12104:10;12095:8;:20::i;:::-;12087:29;;;;;;13456:7;;;;13455:8;13447:17;;;;;;13815:7;:14;;-1:-1:-1;;13815:14:0;13825:4;13815:14;;;13845:18;;;13852:10;13845:18;;;;;;;;;;;;;13755:116::o;16013:87::-;16085:7;16078:14;;;;;;;;-1:-1:-1;;16078:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16052:13;;16078:14;;16085:7;;16078:14;;16085:7;16078:14;;;;;;;;;;;;;;;;;;;;;;;;16850:92;16684:20;16693:10;16684:8;:20::i;:::-;16676:29;;;;;;16915:19;16926:7;16915:10;:19::i;16950:77::-;16994:25;17008:10;16994:13;:25::i;20983:195::-;19370:10;21097:4;19355:26;;;:14;:26;;;;;;21079:7;;19355:26;;19354:27;19346:36;;;;;;-1:-1:-1;;;;;19402:18:0;;;;;;:14;:18;;;;;;;;19401:19;19393:28;;;;;;21121:49;21145:7;21154:15;21121:23;:49::i;20249:145::-;19370:10;20337:4;19355:26;;;:14;:26;;;;;;20324:2;;19355:26;;19354:27;19346:36;;;;;;-1:-1:-1;;;;;19402:18:0;;;;;;:14;:18;;;;;;;;19401:19;19393:28;;;;;;20361:25;20376:2;20380:5;20361:14;:25::i;16733:109::-;16789:4;16813:21;:8;16826:7;16813:21;:12;:21;:::i;4484:131::-;-1:-1:-1;;;;;4583:15:0;;;4556:7;4583:15;;;:8;:15;;;;;;;;:24;;;;;;;;;;;;;4484:131::o;20042:199::-;12095:20;12104:10;12095:8;:20::i;:::-;12087:29;;;;;;13456:7;;;;13455:8;13447:17;;;;;;-1:-1:-1;;;;;20134:31:0;;20168:5;20134:31;;;:14;:31;;;;;;;;;:39;;-1:-1:-1;;20134:39:0;;;20189:44;;;;;20222:10;20189:44;;;;;;;;;;;;;;;;20042:199;:::o;14638:140::-;13456:7;;14717:4;;13456:7;;13455:8;13447:17;;;;;;14741:29;14755:7;14764:5;14741:13;:29::i;:::-;14734:36;14638:140;-1:-1:-1;;;14638:140:0:o;14470:160::-;13456:7;;14563:4;;13456:7;;13455:8;13447:17;;;;;;14587:35;14606:4;14612:2;14616:5;14587:18;:35::i;14786:175::-;13456:7;;14877:12;;13456:7;;13455:8;13447:17;;;;;;14909:44;14933:7;14942:10;14909:23;:44::i;18403:154::-;18506:4;;18478:24;18496:5;18478:13;:11;:13::i;:::-;:17;:24;:17;:24;:::i;:::-;:32;;18470:41;;;;;;18522:27;18534:7;18543:5;18522:11;:27::i;9242:269::-;-1:-1:-1;;;;;9317:21:0;;9309:30;;;;;;9367:12;;:23;;9384:5;9367:23;:16;:23;:::i;:::-;9352:12;:38;-1:-1:-1;;;;;9422:18:0;;:9;:18;;;;;;;;;;;:29;;9445:5;9422:29;:22;:29;:::i;:::-;-1:-1:-1;;;;;9401:18:0;;:9;:18;;;;;;;;;;;:50;;;;9467:36;;;;;;;9401:9;;9467:36;;;;;;;;;;;9242:269;;:::o;11508:165::-;11580:4;-1:-1:-1;;;;;11605:21:0;;11597:30;;;;;;-1:-1:-1;;;;;;11645:20:0;:11;:20;;;;;;;;;;;;;;;11508:165::o;12576:130::-;12636:24;:8;12652:7;12636:24;:15;:24;:::i;:::-;12676:22;;-1:-1:-1;;;;;12676:22:0;;;;;;;;12576:130;:::o;2095:150::-;2153:7;2186:1;2181;:6;;2173:15;;;;;;-1:-1:-1;2211:5:0;;;2095:150::o;10437:182::-;10508:21;10514:7;10523:5;10508;:21::i;:::-;-1:-1:-1;;;;;10570:17:0;;;;;;:8;:17;;;;;;;;10558:10;10570:29;;;;;;;;;10540:71;;10549:7;;10570:40;;10604:5;10570:40;:33;:40;:::i;:::-;10540:8;:71::i;12446:122::-;12503:21;:8;12516:7;12503:21;:12;:21;:::i;:::-;12540:20;;-1:-1:-1;;;;;12540:20:0;;;;;;;;12446:122;:::o;17035:::-;17092:21;:8;17105:7;17092:21;:12;:21;:::i;:::-;17129:20;;-1:-1:-1;;;;;17129:20:0;;;;;;;;17035:122;:::o;17165:130::-;17225:24;:8;17241:7;17225:24;:15;:24;:::i;:::-;17265:22;;-1:-1:-1;;;;;17265:22:0;;;;;;;;17165:130;:::o;14969:185::-;13456:7;;15065:12;;13456:7;;13455:8;13447:17;;;;;;15097:49;15121:7;15130:15;15097:23;:49::i;14330:132::-;13456:7;;14405:4;;13456:7;;13455:8;13447:17;;;;;;14429:25;14444:2;14448:5;14429:14;:25::i;5576:148::-;5641:4;5658:36;5667:10;5679:7;5688:5;5658:8;:36::i;6197:228::-;6276:4;6293:26;6303:4;6309:2;6313:5;6293:9;:26::i;:::-;-1:-1:-1;;;;;6357:14:0;;;;;;:8;:14;;;;;;;;6345:10;6357:26;;;;;;;;;6330:65;;6339:4;;6357:37;;6388:5;6357:37;:30;:37;:::i;6330:65::-;-1:-1:-1;6413:4:0;6197:228;;;;;:::o;6951:203::-;7057:10;7031:4;7078:20;;;:8;:20;;;;;;;;-1:-1:-1;;;;;7078:29:0;;;;;;;;;;7031:4;;7048:76;;7069:7;;7078:45;;7112:10;7078:45;:33;:45;:::i;2333:150::-;2391:7;2423:5;;;2447:6;;;;2439:15;;;;;8739:269;-1:-1:-1;;;;;8814:21:0;;8806:30;;;;;;8864:12;;:23;;8881:5;8864:23;:16;:23;:::i;:::-;8849:12;:38;-1:-1:-1;;;;;8919:18:0;;:9;:18;;;;;;;;;;;:29;;8942:5;8919:29;:22;:29;:::i;:::-;-1:-1:-1;;;;;8898:18:0;;:9;:18;;;;;;;;;;;:50;;;;8964:36;;;;;;;8898:18;;:9;;8964:36;;;;;;;;;;8739:269;;:::o;11225:189::-;-1:-1:-1;;;;;11305:21:0;;11297:30;;;;;;11346:18;11350:4;11356:7;11346:3;:18::i;:::-;11338:27;;;;;;-1:-1:-1;;;;;11378:20:0;11401:5;11378:20;;;;;;;;;;;:28;;-1:-1:-1;;11378:28:0;;;11225:189::o;9784:254::-;-1:-1:-1;;;;;9877:21:0;;9869:30;;;;;;-1:-1:-1;;;;;9918:19:0;;9910:28;;;;;;-1:-1:-1;;;;;9951:15:0;;;;;;;:8;:15;;;;;;;;:24;;;;;;;;;;;;;:32;;;9999:31;;;;;;;;;;;;;;;;;9784:254;;;:::o;10960:186::-;-1:-1:-1;;;;;11037:21:0;;11029:30;;;;;;11079:18;11083:4;11089:7;11079:3;:18::i;:::-;11078:19;11070:28;;;;;;-1:-1:-1;;;;;11111:20:0;:11;:20;;;;;;;;;;;:27;;-1:-1:-1;;11111:27:0;11134:4;11111:27;;;10960:186::o;7685:213::-;7796:10;7770:4;7817:20;;;:8;:20;;;;;;;;-1:-1:-1;;;;;7817:29:0;;;;;;;;;;7770:4;;7787:81;;7808:7;;7817:50;;7851:15;7817:50;:33;:50;:::i;4789:140::-;4850:4;4867:32;4877:10;4889:2;4893:5;8125:262;-1:-1:-1;;;;;8213:16:0;;8205:25;;;;;;-1:-1:-1;;;;;8261:15:0;;:9;:15;;;;;;;;;;;:26;;8281:5;8261:26;:19;:26;:::i;:::-;-1:-1:-1;;;;;8243:15:0;;;:9;:15;;;;;;;;;;;:44;;;;8314:13;;;;;;;:24;;8332:5;8314:24;:17;:24;:::i;:::-;-1:-1:-1;;;;;8298:13:0;;;:9;:13;;;;;;;;;;;;:40;;;;8354:25;;;;;;;8298:13;;8354:25;;;;;;;;;;;;;8125:262;;;:::o

Swarm Source

bzzr://b718fdaf5b1c14dc308681e2f95ad97b42db0cac7934bf9d0a6ba2d09e424fae
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.