ETH Price: $3,641.12 (+0.76%)
 

Overview

Max Total Supply

350,000,000 HCI

Holders

3,322

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 8 Decimals)

Balance
20 HCI

Value
$0.00
0x94d78fa3c72b1b8bdf8394ffee840185f56b28d1
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:
HotelCoin

Compiler Version
v0.4.19+commit.c4cbbb05

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2018-02-28
*/

pragma solidity 0.4.19;


/**
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 */
library SafeMath {
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a * b;
        require(a == 0 || c / a == b);
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        // assert(b > 0); // Solidity automatically throws 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;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a);
        return a - b;
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a);
        return c;
    }
}

/**
 * @title ERC20Basic
 * @dev Simpler version of ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/179
 */
contract ERC20Basic {
    uint256 public totalSupply;
    function balanceOf(address who) public view returns (uint256);
    function transfer(address to, uint256 value) public returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
}

/**
 * @title Basic token
 * @dev Basic version of StandardToken, with no allowances.
 */
contract BasicToken is ERC20Basic {
    using SafeMath for uint256;

    mapping(address => uint256) public balances;

    /**
    * @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) {
        require(_to != address(0));
        require(_value <= balances[msg.sender]);

        // SafeMath.sub will throw if there is not enough balance.
        balances[msg.sender] = balances[msg.sender].sub(_value);
        balances[_to] = balances[_to].add(_value);
        Transfer(msg.sender, _to, _value);
        return true;
    }

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

}

/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
contract ERC20 is ERC20Basic {
    function allowance(address owner, address spender) public view returns (uint256);
    function transferFrom(address from, address to, uint256 value) public returns (bool);
    function approve(address spender, uint256 value) public returns (bool);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure.
 * To use this library you can add a `using SafeERC20 for ERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    function safeTransfer(ERC20Basic token, address to, uint256 value) internal {
        assert(token.transfer(to, value));
    }

    function safeTransferFrom(ERC20 token, address from, address to, uint256 value) internal {
        assert(token.transferFrom(from, to, value));
    }

    function safeApprove(ERC20 token, address spender, uint256 value) internal {
        assert(token.approve(spender, value));
    }
}

/**
 * @title TokenTimelock
 * @dev TokenTimelock is a token holder contract that will allow a
 * beneficiary to extract the tokens after a given release time
 */
contract TokenTimelock {
    using SafeERC20 for ERC20Basic;

    // ERC20 basic token contract being held
    ERC20Basic public token;

    // beneficiary of tokens after they are released
    address public beneficiary;

    // timestamp when token release is enabled
    uint64 public releaseTime;

    function TokenTimelock(ERC20Basic _token, address _beneficiary, uint64 _releaseTime) public {
        require(_releaseTime > uint64(block.timestamp));
        token = _token;
        beneficiary = _beneficiary;
        releaseTime = _releaseTime;
    }

    /**
     * @notice Transfers tokens held by timelock to beneficiary.
     */
    function release() public {
        require(uint64(block.timestamp) >= releaseTime);

        uint256 amount = token.balanceOf(this);
        require(amount > 0);

        token.safeTransfer(beneficiary, amount);
    }
}

/**
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * @dev https://github.com/ethereum/EIPs/issues/20
 * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
contract StandardToken is ERC20, BasicToken {

    mapping (address => mapping (address => uint256)) internal allowed;


    /**
     * @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(_to != address(0));
        require(_value <= balances[_from]);
        require(_value <= allowed[_from][msg.sender]);

        balances[_from] = balances[_from].sub(_value);
        balances[_to] = balances[_to].add(_value);
        allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
        Transfer(_from, _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) {
        allowed[msg.sender][_spender] = _value;
        Approval(msg.sender, _spender, _value);
        return true;
    }

    /**
     * @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 remaining) {
        return allowed[_owner][_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
     */
    function increaseApproval (address _spender, uint _addedValue) public returns (bool success) {
        allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue);
        Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
        return true;
    }

    function decreaseApproval (address _spender, uint _subtractedValue) public returns (bool success) {
        uint oldValue = allowed[msg.sender][_spender];
        if (_subtractedValue > oldValue) {
            allowed[msg.sender][_spender] = 0;
        } else {
            allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
        }
        Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
        return true;
    }
}

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

    event Burn(address indexed burner, uint256 value);

    /**
     * @dev Burns a specific amount of tokens.
     * @param _value The amount of token to be burned.
     */
    function burn(uint256 _value) public {
        require(_value > 0);
        require(_value <= balances[msg.sender]);
        // no need to require value <= totalSupply, since that would imply the
        // sender's balance is greater than the totalSupply, which *should* be an assertion failure

        address burner = msg.sender;
        balances[burner] = balances[burner].sub(_value);
        totalSupply = totalSupply.sub(_value);
        Burn(burner, _value);
    }
}

contract Owned {
    address public owner;

    function Owned() public {
        owner = msg.sender;
    }

    modifier onlyOwner {
        require(msg.sender == owner);
        _;
    }
}

contract HotelCoin is BurnableToken, Owned {
    string public constant name = "Hotel Coin";
    string public constant symbol = "HCI";
    uint8 public constant decimals = 8;

    /// Maximum tokens to be allocated (350 million)
    uint256 public constant HARD_CAP = 350000000 * 10**uint256(decimals);

    /// The owner of this address is the HCI Liquidity Fund
    address public liquidityFundAddress;

    /// This address is used to keep the tokens for bonuses
    address public communityTokensAddress;

    /// When the sale is closed, no more tokens can be issued
    uint64 public tokenSaleClosedTime = 0;

    /// Trading opening date deadline (21/Jun/2018)
    uint64 private constant date21Jun2018 = 1529517600;

    /// Used to look up the locking contract for each locked tokens owner
    mapping(address => address) public lockingContractAddresses;

    /// Only allowed to execute before the sale is closed
    modifier beforeEnd {
        require(tokenSaleClosedTime == 0);
        _;
    }

    function HotelCoin(address _liquidityFundAddress, address _communityTokensAddress) public {
        require(_liquidityFundAddress != address(0));
        require(_communityTokensAddress != address(0));

        liquidityFundAddress = _liquidityFundAddress;
        communityTokensAddress = _communityTokensAddress;

        /// Tokens for sale, Partnership, Board of Advisors and team - 280 million HCI
        uint256 saleTokens = 280000000 * 10**uint256(decimals);
        totalSupply = saleTokens;
        balances[owner] = saleTokens;
        Transfer(0x0, owner, saleTokens);

        /// Community and Affiliates pools tokens - 52.5 million
        uint256 communityTokens = 52500000 * 10**uint256(decimals);
        totalSupply = totalSupply.add(communityTokens);
        balances[communityTokensAddress] = communityTokens;
        Transfer(0x0, communityTokensAddress, communityTokens);

        /// Liquidity tokens - 17.5 million
        uint256 liquidityTokens = 17500000 * 10**uint256(decimals);
        totalSupply = totalSupply.add(liquidityTokens);
        balances[liquidityFundAddress] = liquidityTokens;
        Transfer(0x0, liquidityFundAddress, liquidityTokens);
    }

    /// @dev start the trading countdown
    function close() public onlyOwner beforeEnd {
        require(totalSupply <= HARD_CAP);
        tokenSaleClosedTime = uint64(block.timestamp);
    }

    /// @dev Transfer timelocked tokens; ignores _releaseTime if a timelock exists already
    function transferLocking(address _to, uint256 _value, uint64 _releaseTime) public onlyOwner returns (bool) {
        address timelockAddress = lockingContractAddresses[_to];
        if(timelockAddress == address(0)) {
            TokenTimelock timelock = new TokenTimelock(this, _to, _releaseTime);
            timelockAddress = address(timelock);
            lockingContractAddresses[_to] = timelockAddress;
        }

        return super.transfer(timelockAddress, _value);
    }

    /// @dev check the locked balance of an owner
    function lockedBalanceOf(address _owner) public view returns (uint256) {
        return balances[lockingContractAddresses[_owner]];
    }

    /// @dev get the TokenTimelock contract address for an owner
    function timelockOf(address _owner) public view returns (address) {
        return lockingContractAddresses[_owner];
    }

    /// @dev 21 days after the closing of the sale
    function tradingOpen() public view returns (bool) {
        return (tokenSaleClosedTime != 0 && block.timestamp > tokenSaleClosedTime + 60 * 60 * 24 * 21)
        || block.timestamp > date21Jun2018;
    }

    /// @dev Trading limited - requires 3 weeks to have passed since the sale closed
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
        if(tradingOpen() || msg.sender == owner || msg.sender == communityTokensAddress) {
            return super.transferFrom(_from, _to, _value);
        }
        return false;
    }

    /// @dev Trading limited - requires 3 weeks to have passed since the sale closed
    function transfer(address _to, uint256 _value) public returns (bool) {
        if(tradingOpen() || msg.sender == owner || msg.sender == communityTokensAddress) {
            return super.transfer(_to, _value);
        }
        return false;
    }
}

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":true,"inputs":[],"name":"communityTokensAddress","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"liquidityFundAddress","outputs":[{"name":"","type":"address"}],"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":"","type":"address"}],"name":"balances","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"lockingContractAddresses","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"HARD_CAP","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_value","type":"uint256"}],"name":"burn","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"close","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"lockedBalanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_subtractedValue","type":"uint256"}],"name":"decreaseApproval","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"balance","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"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":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"timelockOf","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_addedValue","type":"uint256"}],"name":"increaseApproval","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_value","type":"uint256"},{"name":"_releaseTime","type":"uint64"}],"name":"transferLocking","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"remaining","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"tokenSaleClosedTime","outputs":[{"name":"","type":"uint64"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"tradingOpen","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_liquidityFundAddress","type":"address"},{"name":"_communityTokensAddress","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"name":"burner","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Burn","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":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"}]

60606040526005805460a060020a60e060020a0319169055341561002257600080fd5b60405160408061140f833981016040528080519190602001805160038054600160a060020a03191633600160a060020a039081169190911790915590925060009150819081908516151561007557600080fd5b600160a060020a038416151561008a57600080fd5b60048054600160a060020a03808816600160a060020a031992831617909255600580548784169216919091179055666379da05b60000600081815560038054841682526001602052604080832084905590549296509190921691906000805160206113ef8339815191529086905190815260200160405180910390a36000546612a6d8e1122000925061012a9083640100000000610e226101ea82021704565b600090815560058054600160a060020a0390811683526001602052604080842086905591541691906000805160206113ef8339815191529085905190815260200160405180910390a3506000546606379da05b6000906101979082640100000000610e226101ea82021704565b600090815560048054600160a060020a0390811683526001602052604080842085905591541691906000805160206113ef8339815191529084905190815260200160405180910390a35050505050610203565b6000828201838110156101fc57600080fd5b9392505050565b6111dd806102126000396000f30060606040526004361061013d5763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde038114610142578063095ea7b3146101cc5780630f53b7ee1461020257806318160ddd146102315780631882d2671461025657806323b872dd1461026957806327e235e31461029157806330a0f5d3146102b0578063313ce567146102cf5780633a03171c146102f857806342966c681461030b57806343d726d6146103235780635935573614610336578063661884631461035557806370a08231146103775780638da5cb5b1461039657806395d89b41146103a9578063a9059cbb146103bc578063c1708ad4146103de578063d73dd623146103fd578063db74dc371461041f578063dd62ed3e1461044e578063f1bbc66314610473578063ffb54a99146104a3575b600080fd5b341561014d57600080fd5b6101556104b6565b60405160208082528190810183818151815260200191508051906020019080838360005b83811015610191578082015183820152602001610179565b50505050905090810190601f1680156101be5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101d757600080fd5b6101ee600160a060020a03600435166024356104ed565b604051901515815260200160405180910390f35b341561020d57600080fd5b61021561055a565b604051600160a060020a03909116815260200160405180910390f35b341561023c57600080fd5b610244610569565b60405190815260200160405180910390f35b341561026157600080fd5b61021561056f565b341561027457600080fd5b6101ee600160a060020a036004358116906024351660443561057e565b341561029c57600080fd5b610244600160a060020a03600435166105dc565b34156102bb57600080fd5b610215600160a060020a03600435166105ee565b34156102da57600080fd5b6102e2610609565b60405160ff909116815260200160405180910390f35b341561030357600080fd5b61024461060e565b341561031657600080fd5b610321600435610619565b005b341561032e57600080fd5b6103216106e2565b341561034157600080fd5b610244600160a060020a036004351661076e565b341561036057600080fd5b6101ee600160a060020a0360043516602435610799565b341561038257600080fd5b610244600160a060020a0360043516610893565b34156103a157600080fd5b6102156108ae565b34156103b457600080fd5b6101556108bd565b34156103c757600080fd5b6101ee600160a060020a03600435166024356108f4565b34156103e957600080fd5b610215600160a060020a036004351661094f565b341561040857600080fd5b6101ee600160a060020a036004351660243561096d565b341561042a57600080fd5b6101ee600160a060020a036004351660243567ffffffffffffffff60443516610a11565b341561045957600080fd5b610244600160a060020a0360043581169060243516610afc565b341561047e57600080fd5b610486610b27565b60405167ffffffffffffffff909116815260200160405180910390f35b34156104ae57600080fd5b6101ee610b3e565b60408051908101604052600a81527f486f74656c20436f696e00000000000000000000000000000000000000000000602082015281565b600160a060020a03338116600081815260026020908152604080832094871680845294909152808220859055909291907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a35060015b92915050565b600554600160a060020a031681565b60005481565b600454600160a060020a031681565b6000610588610b3e565b806105a1575060035433600160a060020a039081169116145b806105ba575060055433600160a060020a039081169116145b156105d1576105ca848484610b90565b90506105d5565b5060005b9392505050565b60016020526000908152604090205481565b600660205260009081526040902054600160a060020a031681565b600881565b667c58508723800081565b600080821161062757600080fd5b600160a060020a03331660009081526001602052604090205482111561064c57600080fd5b5033600160a060020a0381166000908152600160205260409020546106719083610d12565b600160a060020a0382166000908152600160205260408120919091555461069e908363ffffffff610d1216565b600055600160a060020a0381167fcc16f5dbb4873280815c1ee09dbd06736cffcc184412cf7a71a0fdb75d397ca58360405190815260200160405180910390a25050565b60035433600160a060020a039081169116146106fd57600080fd5b60055460a060020a900467ffffffffffffffff161561071b57600080fd5b600054667c58508723800090111561073257600080fd5b600580547fffffffff0000000000000000ffffffffffffffffffffffffffffffffffffffff1660a060020a4267ffffffffffffffff1602179055565b600160a060020a03908116600090815260066020908152604080832054909316825260019052205490565b600160a060020a033381166000908152600260209081526040808320938616835292905290812054808311156107f657600160a060020a03338116600090815260026020908152604080832093881683529290529081205561082d565b610806818463ffffffff610d1216565b600160a060020a033381166000908152600260209081526040808320938916835292905220555b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020547f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925915190815260200160405180910390a35060019392505050565b600160a060020a031660009081526001602052604090205490565b600354600160a060020a031681565b60408051908101604052600381527f4843490000000000000000000000000000000000000000000000000000000000602082015281565b60006108fe610b3e565b80610917575060035433600160a060020a039081169116145b80610930575060055433600160a060020a039081169116145b156109465761093f8383610d27565b9050610554565b50600092915050565b600160a060020a039081166000908152600660205260409020541690565b600160a060020a0333811660009081526002602090815260408083209386168352929052908120546109a5908363ffffffff610e2216565b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020849055919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591905190815260200160405180910390a350600192915050565b6003546000908190819033600160a060020a03908116911614610a3357600080fd5b600160a060020a03808716600090815260066020526040902054169150811515610ae857308685610a62610e34565b600160a060020a03938416815291909216602082015267ffffffffffffffff90911660408083019190915260609091019051809103906000f0801515610aa757600080fd5b600160a060020a038781166000908152600660205260409020805473ffffffffffffffffffffffffffffffffffffffff191691831691909117905591508190505b610af28286610d27565b9695505050505050565b600160a060020a03918216600090815260026020908152604080832093909416825291909152205490565b60055460a060020a900467ffffffffffffffff1681565b60055460009060a060020a900467ffffffffffffffff1615801590610b7d5750600554621baf8067ffffffffffffffff60a060020a9092048216011642115b80610b8b5750635b2a962042115b905090565b6000600160a060020a0383161515610ba757600080fd5b600160a060020a038416600090815260016020526040902054821115610bcc57600080fd5b600160a060020a0380851660009081526002602090815260408083203390941683529290522054821115610bff57600080fd5b600160a060020a038416600090815260016020526040902054610c28908363ffffffff610d1216565b600160a060020a038086166000908152600160205260408082209390935590851681522054610c5d908363ffffffff610e2216565b600160a060020a03808516600090815260016020908152604080832094909455878316825260028152838220339093168252919091522054610ca5908363ffffffff610d1216565b600160a060020a03808616600081815260026020908152604080832033861684529091529081902093909355908516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060019392505050565b600082821115610d2157600080fd5b50900390565b6000600160a060020a0383161515610d3e57600080fd5b600160a060020a033316600090815260016020526040902054821115610d6357600080fd5b600160a060020a033316600090815260016020526040902054610d8c908363ffffffff610d1216565b600160a060020a033381166000908152600160205260408082209390935590851681522054610dc1908363ffffffff610e2216565b600160a060020a0380851660008181526001602052604090819020939093559133909116907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a350600192915050565b6000828201838110156105d557600080fd5b60405161036d80610e458339019056006060604052341561000f57600080fd5b60405160608061036d8339810160405280805191906020018051919060200180519150506001604060020a034281169082161161004b57600080fd5b60008054600160a060020a0319908116600160a060020a0395861617825560018054909116939094169290921760a060020a60e060020a031916740100000000000000000000000000000000000000006001604060020a039290921691909102179091556102ae9081906100bf90396000f3006060604052600436106100485763ffffffff60e060020a60003504166338af3eed811461004d57806386d1a69f1461007c578063b91d400114610091578063fc0c546a146100c1575b600080fd5b341561005857600080fd5b6100606100d4565b604051600160a060020a03909116815260200160405180910390f35b341561008757600080fd5b61008f6100e3565b005b341561009c57600080fd5b6100a46101c6565b60405167ffffffffffffffff909116815260200160405180910390f35b34156100cc57600080fd5b6100606101ee565b600154600160a060020a031681565b60015460009067ffffffffffffffff74010000000000000000000000000000000000000000909104811642909116101561011c57600080fd5b60008054600160a060020a0316906370a082319030906040516020015260405160e060020a63ffffffff8416028152600160a060020a039091166004820152602401602060405180830381600087803b151561017757600080fd5b6102c65a03f1151561018857600080fd5b5050506040518051915050600081116101a057600080fd5b6001546000546101c391600160a060020a0391821691168363ffffffff6101fd16565b50565b60015474010000000000000000000000000000000000000000900467ffffffffffffffff1681565b600054600160a060020a031681565b82600160a060020a031663a9059cbb838360006040516020015260405160e060020a63ffffffff8516028152600160a060020a0390921660048301526024820152604401602060405180830381600087803b151561025a57600080fd5b6102c65a03f1151561026b57600080fd5b50505060405180519050151561027d57fe5b5050505600a165627a7a72305820bff7c6f968ee57af790be061eeddd73b2d2fc839ac9fedd7adf3bd5f5a6259d60029a165627a7a72305820cffb97395e6838d7fc80b625e39b41f839eb5db8700e3157cdae5a1574e86dbb0029ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef000000000000000000000000e3c5b5550c48335134666ceb59f445e39be6138e00000000000000000000000058444d2d36a8a3fc46d374980242850453c63492

Deployed Bytecode

0x60606040526004361061013d5763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde038114610142578063095ea7b3146101cc5780630f53b7ee1461020257806318160ddd146102315780631882d2671461025657806323b872dd1461026957806327e235e31461029157806330a0f5d3146102b0578063313ce567146102cf5780633a03171c146102f857806342966c681461030b57806343d726d6146103235780635935573614610336578063661884631461035557806370a08231146103775780638da5cb5b1461039657806395d89b41146103a9578063a9059cbb146103bc578063c1708ad4146103de578063d73dd623146103fd578063db74dc371461041f578063dd62ed3e1461044e578063f1bbc66314610473578063ffb54a99146104a3575b600080fd5b341561014d57600080fd5b6101556104b6565b60405160208082528190810183818151815260200191508051906020019080838360005b83811015610191578082015183820152602001610179565b50505050905090810190601f1680156101be5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101d757600080fd5b6101ee600160a060020a03600435166024356104ed565b604051901515815260200160405180910390f35b341561020d57600080fd5b61021561055a565b604051600160a060020a03909116815260200160405180910390f35b341561023c57600080fd5b610244610569565b60405190815260200160405180910390f35b341561026157600080fd5b61021561056f565b341561027457600080fd5b6101ee600160a060020a036004358116906024351660443561057e565b341561029c57600080fd5b610244600160a060020a03600435166105dc565b34156102bb57600080fd5b610215600160a060020a03600435166105ee565b34156102da57600080fd5b6102e2610609565b60405160ff909116815260200160405180910390f35b341561030357600080fd5b61024461060e565b341561031657600080fd5b610321600435610619565b005b341561032e57600080fd5b6103216106e2565b341561034157600080fd5b610244600160a060020a036004351661076e565b341561036057600080fd5b6101ee600160a060020a0360043516602435610799565b341561038257600080fd5b610244600160a060020a0360043516610893565b34156103a157600080fd5b6102156108ae565b34156103b457600080fd5b6101556108bd565b34156103c757600080fd5b6101ee600160a060020a03600435166024356108f4565b34156103e957600080fd5b610215600160a060020a036004351661094f565b341561040857600080fd5b6101ee600160a060020a036004351660243561096d565b341561042a57600080fd5b6101ee600160a060020a036004351660243567ffffffffffffffff60443516610a11565b341561045957600080fd5b610244600160a060020a0360043581169060243516610afc565b341561047e57600080fd5b610486610b27565b60405167ffffffffffffffff909116815260200160405180910390f35b34156104ae57600080fd5b6101ee610b3e565b60408051908101604052600a81527f486f74656c20436f696e00000000000000000000000000000000000000000000602082015281565b600160a060020a03338116600081815260026020908152604080832094871680845294909152808220859055909291907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a35060015b92915050565b600554600160a060020a031681565b60005481565b600454600160a060020a031681565b6000610588610b3e565b806105a1575060035433600160a060020a039081169116145b806105ba575060055433600160a060020a039081169116145b156105d1576105ca848484610b90565b90506105d5565b5060005b9392505050565b60016020526000908152604090205481565b600660205260009081526040902054600160a060020a031681565b600881565b667c58508723800081565b600080821161062757600080fd5b600160a060020a03331660009081526001602052604090205482111561064c57600080fd5b5033600160a060020a0381166000908152600160205260409020546106719083610d12565b600160a060020a0382166000908152600160205260408120919091555461069e908363ffffffff610d1216565b600055600160a060020a0381167fcc16f5dbb4873280815c1ee09dbd06736cffcc184412cf7a71a0fdb75d397ca58360405190815260200160405180910390a25050565b60035433600160a060020a039081169116146106fd57600080fd5b60055460a060020a900467ffffffffffffffff161561071b57600080fd5b600054667c58508723800090111561073257600080fd5b600580547fffffffff0000000000000000ffffffffffffffffffffffffffffffffffffffff1660a060020a4267ffffffffffffffff1602179055565b600160a060020a03908116600090815260066020908152604080832054909316825260019052205490565b600160a060020a033381166000908152600260209081526040808320938616835292905290812054808311156107f657600160a060020a03338116600090815260026020908152604080832093881683529290529081205561082d565b610806818463ffffffff610d1216565b600160a060020a033381166000908152600260209081526040808320938916835292905220555b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020547f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925915190815260200160405180910390a35060019392505050565b600160a060020a031660009081526001602052604090205490565b600354600160a060020a031681565b60408051908101604052600381527f4843490000000000000000000000000000000000000000000000000000000000602082015281565b60006108fe610b3e565b80610917575060035433600160a060020a039081169116145b80610930575060055433600160a060020a039081169116145b156109465761093f8383610d27565b9050610554565b50600092915050565b600160a060020a039081166000908152600660205260409020541690565b600160a060020a0333811660009081526002602090815260408083209386168352929052908120546109a5908363ffffffff610e2216565b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020849055919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591905190815260200160405180910390a350600192915050565b6003546000908190819033600160a060020a03908116911614610a3357600080fd5b600160a060020a03808716600090815260066020526040902054169150811515610ae857308685610a62610e34565b600160a060020a03938416815291909216602082015267ffffffffffffffff90911660408083019190915260609091019051809103906000f0801515610aa757600080fd5b600160a060020a038781166000908152600660205260409020805473ffffffffffffffffffffffffffffffffffffffff191691831691909117905591508190505b610af28286610d27565b9695505050505050565b600160a060020a03918216600090815260026020908152604080832093909416825291909152205490565b60055460a060020a900467ffffffffffffffff1681565b60055460009060a060020a900467ffffffffffffffff1615801590610b7d5750600554621baf8067ffffffffffffffff60a060020a9092048216011642115b80610b8b5750635b2a962042115b905090565b6000600160a060020a0383161515610ba757600080fd5b600160a060020a038416600090815260016020526040902054821115610bcc57600080fd5b600160a060020a0380851660009081526002602090815260408083203390941683529290522054821115610bff57600080fd5b600160a060020a038416600090815260016020526040902054610c28908363ffffffff610d1216565b600160a060020a038086166000908152600160205260408082209390935590851681522054610c5d908363ffffffff610e2216565b600160a060020a03808516600090815260016020908152604080832094909455878316825260028152838220339093168252919091522054610ca5908363ffffffff610d1216565b600160a060020a03808616600081815260026020908152604080832033861684529091529081902093909355908516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060019392505050565b600082821115610d2157600080fd5b50900390565b6000600160a060020a0383161515610d3e57600080fd5b600160a060020a033316600090815260016020526040902054821115610d6357600080fd5b600160a060020a033316600090815260016020526040902054610d8c908363ffffffff610d1216565b600160a060020a033381166000908152600160205260408082209390935590851681522054610dc1908363ffffffff610e2216565b600160a060020a0380851660008181526001602052604090819020939093559133909116907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a350600192915050565b6000828201838110156105d557600080fd5b60405161036d80610e458339019056006060604052341561000f57600080fd5b60405160608061036d8339810160405280805191906020018051919060200180519150506001604060020a034281169082161161004b57600080fd5b60008054600160a060020a0319908116600160a060020a0395861617825560018054909116939094169290921760a060020a60e060020a031916740100000000000000000000000000000000000000006001604060020a039290921691909102179091556102ae9081906100bf90396000f3006060604052600436106100485763ffffffff60e060020a60003504166338af3eed811461004d57806386d1a69f1461007c578063b91d400114610091578063fc0c546a146100c1575b600080fd5b341561005857600080fd5b6100606100d4565b604051600160a060020a03909116815260200160405180910390f35b341561008757600080fd5b61008f6100e3565b005b341561009c57600080fd5b6100a46101c6565b60405167ffffffffffffffff909116815260200160405180910390f35b34156100cc57600080fd5b6100606101ee565b600154600160a060020a031681565b60015460009067ffffffffffffffff74010000000000000000000000000000000000000000909104811642909116101561011c57600080fd5b60008054600160a060020a0316906370a082319030906040516020015260405160e060020a63ffffffff8416028152600160a060020a039091166004820152602401602060405180830381600087803b151561017757600080fd5b6102c65a03f1151561018857600080fd5b5050506040518051915050600081116101a057600080fd5b6001546000546101c391600160a060020a0391821691168363ffffffff6101fd16565b50565b60015474010000000000000000000000000000000000000000900467ffffffffffffffff1681565b600054600160a060020a031681565b82600160a060020a031663a9059cbb838360006040516020015260405160e060020a63ffffffff8516028152600160a060020a0390921660048301526024820152604401602060405180830381600087803b151561025a57600080fd5b6102c65a03f1151561026b57600080fd5b50505060405180519050151561027d57fe5b5050505600a165627a7a72305820bff7c6f968ee57af790be061eeddd73b2d2fc839ac9fedd7adf3bd5f5a6259d60029a165627a7a72305820cffb97395e6838d7fc80b625e39b41f839eb5db8700e3157cdae5a1574e86dbb0029

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

000000000000000000000000e3c5b5550c48335134666ceb59f445e39be6138e00000000000000000000000058444d2d36a8a3fc46d374980242850453c63492

-----Decoded View---------------
Arg [0] : _liquidityFundAddress (address): 0xE3c5B5550C48335134666CeB59F445E39be6138E
Arg [1] : _communityTokensAddress (address): 0x58444d2d36a8a3Fc46d374980242850453C63492

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 000000000000000000000000e3c5b5550c48335134666ceb59f445e39be6138e
Arg [1] : 00000000000000000000000058444d2d36a8a3fc46d374980242850453c63492


Swarm Source

bzzr://cffb97395e6838d7fc80b625e39b41f839eb5db8700e3157cdae5a1574e86dbb
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.