Feature Tip: Add private address tag to any address under My Name Tag !
ERC-20
Overview
Max Total Supply
1,000,000,000 DCH
Holders
272
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
DClearToken
Compiler Version
v0.4.18+commit.9cf6e910
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2019-07-25 */ pragma solidity ^0.4.18; contract Ownable { address public owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev The Ownable constructor sets the original `owner` of the contract to the sender * account. */ function Ownable() public { owner = msg.sender; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(msg.sender == owner); _; } /** * @dev Allows the current owner to transfer control of the contract to a newOwner. * @param newOwner The address to transfer ownership to. */ function transferOwnership(address newOwner) public onlyOwner { require(newOwner != address(0)); OwnershipTransferred(owner, newOwner); owner = newOwner; } } contract TokenVesting is Ownable { using SafeMath for uint256; using SafeERC20 for ERC20Basic; event Released(uint256 amount); event Revoked(); // beneficiary of tokens after they are released address public beneficiary; uint256 public start; uint256 public period; uint256 public periodDuration; bool public revocable; mapping (address => uint256) public released; mapping (address => bool) public revoked; /** * @dev Creates a vesting contract that vests its balance of any ERC20 token to the * _beneficiary, gradually in a linear fashion until _start + _duration. By then all * of the balance will have vested. * @param _beneficiary address of the beneficiary to whom vested tokens are transferred * @param _revocable whether the vesting is revocable or not */ function TokenVesting(address _beneficiary, uint256 _start, uint256 _period, uint256 _periodDuration, bool _revocable) public { require(_beneficiary != address(0)); beneficiary = _beneficiary; revocable = _revocable; period = _period; periodDuration = _periodDuration; start = _start; } /** * @notice Transfers vested tokens to beneficiary. * @param token ERC20 token which is being vested */ function release(ERC20Basic token) public { uint256 unreleased = releasableAmount(token); require(unreleased > 0); released[token] = released[token].add(unreleased); token.safeTransfer(beneficiary, unreleased); Released(unreleased); } /** * @notice Allows the owner to revoke the vesting. Tokens already vested * remain in the contract, the rest are returned to the owner. * @param token ERC20 token which is being vested */ function revoke(ERC20Basic token) public onlyOwner { require(revocable); require(!revoked[token]); uint256 balance = token.balanceOf(this); uint256 unreleased = releasableAmount(token); uint256 refund = balance.sub(unreleased); revoked[token] = true; token.safeTransfer(owner, refund); Revoked(); } /** * @dev Calculates the amount that has already vested but hasn't been released yet. * @param token ERC20 token which is being vested */ function releasableAmount(ERC20Basic token) public view returns (uint256) { return vestedAmount(token).sub(released[token]); } /** * @dev Calculates the amount that has already vested. * @param token ERC20 token which is being vested */ function vestedAmount(ERC20Basic token) public view returns (uint256) { uint256 currentBalance = token.balanceOf(this); uint256 totalBalance = currentBalance.add(released[token]); if (now >= start.add(period.mul(periodDuration)) || revoked[token]) { return totalBalance; } else { return totalBalance.div(period).mul(now.sub(start).div(periodDuration)); } } } library SafeMath { function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; assert(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) { assert(b <= a); return a - b; } function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; assert(c >= a); return c; } } 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)); } } contract Pausable is Ownable { event Pause(); event Unpause(); bool public paused = false; /** * @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() onlyOwner whenNotPaused public { paused = true; Pause(); } /** * @dev called by the owner to unpause, returns to normal state */ function unpause() onlyOwner whenPaused public { paused = false; Unpause(); } } contract DClearAllocation is Ownable { using SafeMath for uint256; // The token being minted. DClearToken public token; uint256 public initTime = 1565193600;//2019-08-08 00:00:00 uint256 public periodMintReleased = 0; uint256 public periodMintDuration = 31104000;//1 year uint256 public periodMintBalance = 10000000000000000000000000; address public periodMintAddress = 0x0a39AA89C528D086eAA42447520C684f713966c4; // map of address to token vesting contract mapping (address => TokenVesting) public vesting; /** * event for token mint special logging * @param beneficiary who is receiving the tokens * @param tokens amount of tokens given to the beneficiary */ event DClearTokensMintedSpecial(address beneficiary, uint256 tokens); /** * event for token mint logging * @param beneficiary who is receiving the tokens * @param tokens amount of tokens given to the beneficiary */ event DClearTokensMinted(address beneficiary, uint256 tokens); /** * event for time vested token mint logging * @param beneficiary who is receiving the time vested tokens * @param tokens amount of tokens that will be vested to the beneficiary * @param start unix timestamp at which the tokens will start vesting */ event DClearTimeVestingTokensMinted(address beneficiary, uint256 tokens, uint256 start, uint256 periodDuration, uint256 period); /** * event for air drop token mint loggin * @param beneficiary who is receiving the airdrop tokens * @param tokens airdropped */ event DClearAirDropTokensMinted(address beneficiary, uint256 tokens); /** * @dev Creates a new DClearAllocation contract */ function DClearAllocation() public { token = new DClearToken(); } // member function to mint tokens to a beneficiary function mintTokens(address beneficiary, uint256 tokens) public onlyOwner { require(beneficiary != 0x0); require(tokens > 0); require(token.mint(beneficiary, tokens)); DClearTokensMinted(beneficiary, tokens); } function mintTokensSpecial() public onlyOwner { uint256 amount = periodMintBalance.mul((now.sub(initTime)).div(periodMintDuration)); uint256 unreleased = amount.sub(periodMintReleased); require(unreleased > 0); periodMintReleased = periodMintReleased.add(unreleased); require(token.mintSpecial(periodMintAddress, unreleased)); DClearTokensMintedSpecial(periodMintAddress, unreleased); } // member function to mint time based vesting tokens to a beneficiary function mintTokensWithTimeBasedVesting(address beneficiary, uint256 tokens, uint256 start, uint256 period, uint256 periodDuration) public onlyOwner { require(beneficiary != 0x0); require(tokens > 0); vesting[beneficiary] = new TokenVesting(beneficiary, start, period, periodDuration, false); require(token.mint(address(vesting[beneficiary]), tokens)); DClearTimeVestingTokensMinted(beneficiary, tokens, start, period, periodDuration); } function mintAirDropTokens(uint256 tokens, address[] addresses) public onlyOwner { require(tokens > 0); for (uint256 i = 0; i < addresses.length; i++) { require(token.mint(addresses[i], tokens)); DClearAirDropTokensMinted(addresses[i], tokens); } } // member function to finish the minting process function finishAllocation() public onlyOwner { require(token.finishMinting()); } // member function to unlock token for trading function unlockToken() public onlyOwner { token.unlockToken(); } // member function that can be called to release vested tokens periodically function releaseVestedTokens(address beneficiary) public { require(beneficiary != 0x0); TokenVesting tokenVesting = vesting[beneficiary]; tokenVesting.release(token); } // transfer token ownership after allocation function transferTokenOwnership(address owner) public onlyOwner { require(token.mintingFinished()); token.transferOwnership(owner); } } 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); } 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); } contract BasicToken is ERC20Basic { using SafeMath for uint256; mapping(address => uint256) 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]; } } 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) { return allowed[_owner][_spender]; } /** * @dev Increase the amount of tokens that an owner allowed to a spender. * * approve should be called when allowed[_spender] == 0. To increment * allowed value is better to use this function to avoid 2 calls (and wait until * the first transaction is mined) * From MonolithDAO Token.sol * @param _spender The address which will spend the funds. * @param _addedValue The amount of tokens to increase the allowance by. */ function increaseApproval(address _spender, uint _addedValue) public returns (bool) { allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue); Approval(msg.sender, _spender, allowed[msg.sender][_spender]); return true; } /** * @dev Decrease the amount of tokens that an owner allowed to a spender. * * approve should be called when allowed[_spender] == 0. To decrement * allowed value is better to use this function to avoid 2 calls (and wait until * the first transaction is mined) * From MonolithDAO Token.sol * @param _spender The address which will spend the funds. * @param _subtractedValue The amount of tokens to decrease the allowance by. */ function decreaseApproval(address _spender, uint _subtractedValue) public returns (bool) { 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; } } contract MintableToken is StandardToken, Ownable { event Mint(address indexed to, uint256 amount); event MintFinished(); bool public mintingFinished = false; modifier canMint() { require(!mintingFinished); _; } /** * @dev Function to mint tokens * @param _to The address that will receive the minted tokens. * @param _amount The amount of tokens to mint. * @return A boolean that indicates if the operation was successful. */ function mint(address _to, uint256 _amount) onlyOwner canMint public returns (bool) { totalSupply = totalSupply.add(_amount); balances[_to] = balances[_to].add(_amount); Mint(_to, _amount); Transfer(address(0), _to, _amount); return true; } /** * @dev Function to mint tokens * @param _to The address that will receive the minted tokens. * @param _amount The amount of tokens to mint. * @return A boolean that indicates if the operation was successful. */ function mintSpecial(address _to, uint256 _amount) onlyOwner public returns (bool) { totalSupply = totalSupply.add(_amount); balances[_to] = balances[_to].add(_amount); Mint(_to, _amount); Transfer(address(0), _to, _amount); return true; } /** * @dev Function to stop minting new tokens. * @return True if the operation was successful. */ function finishMinting() onlyOwner canMint public returns (bool) { mintingFinished = true; MintFinished(); return true; } } contract DClearToken is MintableToken { string public constant name = "DClearToken"; string public constant symbol = "DCH"; uint8 public constant decimals = 18; uint256 public constant MAX_INIT_SUPPLY = 1 * 1000 * 1000 * 1000 * (10 ** uint256(decimals)); // Bit that controls whether the token can be transferred / traded bool public unlocked = false; event DClearTokenUnlocked(); /** * @dev totalSupply is set via the minting process */ function DClearToken() public { } function mint(address to, uint256 amount) onlyOwner public returns (bool) { require(totalSupply + amount <= MAX_INIT_SUPPLY); return super.mint(to, amount); } function mintSpecial(address to, uint256 amount) onlyOwner public returns (bool) { return super.mintSpecial(to, amount); } function unlockToken() onlyOwner public { require (!unlocked); unlocked = true; DClearTokenUnlocked(); } // Overriding basic ERC-20 specification that lets people transfer/approve tokens. function transfer(address to, uint256 value) public returns (bool) { require(unlocked); return super.transfer(to, value); } function transferFrom(address from, address to, uint256 value) public returns (bool) { require(unlocked); return super.transferFrom(from, to, value); } function approve(address spender, uint256 value) public returns (bool) { require(unlocked); return super.approve(spender, value); } // Overriding StandardToken functions that lets people transfer/approve tokens. function increaseApproval(address spender, uint addedValue) public returns (bool) { require(unlocked); return super.increaseApproval(spender, addedValue); } function decreaseApproval(address spender, uint subtractedValue) public returns (bool) { require(unlocked); return super.decreaseApproval(spender, subtractedValue); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"constant":true,"inputs":[],"name":"mintingFinished","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"value","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unlockToken","outputs":[],"payable":false,"stateMutability":"nonpayable","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":false,"inputs":[{"name":"to","type":"address"},{"name":"amount","type":"uint256"}],"name":"mint","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"MAX_INIT_SUPPLY","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":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"unlocked","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"balance","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"finishMinting","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"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":false,"inputs":[{"name":"to","type":"address"},{"name":"amount","type":"uint256"}],"name":"mintSpecial","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"addedValue","type":"uint256"}],"name":"increaseApproval","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":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[],"name":"DClearTokenUnlocked","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"amount","type":"uint256"}],"name":"Mint","type":"event"},{"anonymous":false,"inputs":[],"name":"MintFinished","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","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"}]
Contract Creation Code
60606040526000600360146101000a81548160ff0219169083151502179055506000600360156101000a81548160ff021916908315150217905550341561004557600080fd5b33600360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550611d1d806100956000396000f300606060405260043610610112576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff16806305d2035b1461011757806306fdde0314610144578063095ea7b3146101d257806318160ddd1461022c57806318a24b5b1461025557806323b872dd1461026a578063313ce567146102e357806340c10f191461031257806341e1f7811461036c57806366188463146103955780636a5e2650146103ef57806370a082311461041c5780637d64bcb4146104695780638da5cb5b1461049657806395d89b41146104eb578063a9059cbb14610579578063c7ec3be2146105d3578063d73dd6231461062d578063dd62ed3e14610687578063f2fde38b146106f3575b600080fd5b341561012257600080fd5b61012a61072c565b604051808215151515815260200191505060405180910390f35b341561014f57600080fd5b61015761073f565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561019757808201518184015260208101905061017c565b50505050905090810190601f1680156101c45780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101dd57600080fd5b610212600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610778565b604051808215151515815260200191505060405180910390f35b341561023757600080fd5b61023f6107a7565b6040518082815260200191505060405180910390f35b341561026057600080fd5b6102686107ad565b005b341561027557600080fd5b6102c9600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803590602001909190505061086e565b604051808215151515815260200191505060405180910390f35b34156102ee57600080fd5b6102f661089f565b604051808260ff1660ff16815260200191505060405180910390f35b341561031d57600080fd5b610352600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919080359060200190919050506108a4565b604051808215151515815260200191505060405180910390f35b341561037757600080fd5b61037f610934565b6040518082815260200191505060405180910390f35b34156103a057600080fd5b6103d5600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610945565b604051808215151515815260200191505060405180910390f35b34156103fa57600080fd5b610402610974565b604051808215151515815260200191505060405180910390f35b341561042757600080fd5b610453600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610987565b6040518082815260200191505060405180910390f35b341561047457600080fd5b61047c6109d0565b604051808215151515815260200191505060405180910390f35b34156104a157600080fd5b6104a9610a98565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156104f657600080fd5b6104fe610abe565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561053e578082015181840152602081019050610523565b50505050905090810190601f16801561056b5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561058457600080fd5b6105b9600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610af7565b604051808215151515815260200191505060405180910390f35b34156105de57600080fd5b610613600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610b26565b604051808215151515815260200191505060405180910390f35b341561063857600080fd5b61066d600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610b96565b604051808215151515815260200191505060405180910390f35b341561069257600080fd5b6106dd600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610bc5565b6040518082815260200191505060405180910390f35b34156106fe57600080fd5b61072a600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610c4c565b005b600360149054906101000a900460ff1681565b6040805190810160405280600b81526020017f44436c656172546f6b656e00000000000000000000000000000000000000000081525081565b6000600360159054906101000a900460ff16151561079557600080fd5b61079f8383610da4565b905092915050565b60005481565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561080957600080fd5b600360159054906101000a900460ff1615151561082557600080fd5b6001600360156101000a81548160ff0219169083151502179055507f8a8c1d49e289f119bff9803579c0e72a9ad347ef85c0d07d867af78b94039c6360405160405180910390a1565b6000600360159054906101000a900460ff16151561088b57600080fd5b610896848484610e96565b90509392505050565b601281565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561090257600080fd5b601260ff16600a0a633b9aca000282600054011115151561092257600080fd5b61092c8383611255565b905092915050565b601260ff16600a0a633b9aca000281565b6000600360159054906101000a900460ff16151561096257600080fd5b61096c838361143d565b905092915050565b600360159054906101000a900460ff1681565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610a2e57600080fd5b600360149054906101000a900460ff16151515610a4a57600080fd5b6001600360146101000a81548160ff0219169083151502179055507fae5184fba832cb2b1f702aca6117b8d265eaf03ad33eb133f19dde0f5920fa0860405160405180910390a16001905090565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6040805190810160405280600381526020017f444348000000000000000000000000000000000000000000000000000000000081525081565b6000600360159054906101000a900460ff161515610b1457600080fd5b610b1e83836116ce565b905092915050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610b8457600080fd5b610b8e83836118f2565b905092915050565b6000600360159054906101000a900460ff161515610bb357600080fd5b610bbd8383611abe565b905092915050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610ca857600080fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515610ce457600080fd5b8073ffffffffffffffffffffffffffffffffffffffff16600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a380600360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600081600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040518082815260200191505060405180910390a36001905092915050565b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614151515610ed357600080fd5b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548211151515610f2157600080fd5b600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548211151515610fac57600080fd5b610ffe82600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061109382600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061116582600260008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a3600190509392505050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161415156112b357600080fd5b600360149054906101000a900460ff161515156112cf57600080fd5b6112e482600054611cd390919063ffffffff16565b60008190555061133c82600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff167f0f6798a560793a54c3bcfe86a93cde1e73087d944c0ea20544137d4121396885836040518082815260200191505060405180910390a28273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b600080600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508083111561154e576000600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055506115e2565b6115618382611cba90919063ffffffff16565b600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055505b8373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546040518082815260200191505060405180910390a3600191505092915050565b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415151561170b57600080fd5b600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054821115151561175957600080fd5b6117ab82600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061184082600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561195057600080fd5b61196582600054611cd390919063ffffffff16565b6000819055506119bd82600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff167f0f6798a560793a54c3bcfe86a93cde1e73087d944c0ea20544137d4121396885836040518082815260200191505060405180910390a28273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b6000611b4f82600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546040518082815260200191505060405180910390a36001905092915050565b6000828211151515611cc857fe5b818303905092915050565b6000808284019050838110151515611ce757fe5b80915050929150505600a165627a7a72305820423cd54259ced0826a49d40582ce142ea68b743390963fd72d9de9a4cb70044b0029
Deployed Bytecode
0x606060405260043610610112576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff16806305d2035b1461011757806306fdde0314610144578063095ea7b3146101d257806318160ddd1461022c57806318a24b5b1461025557806323b872dd1461026a578063313ce567146102e357806340c10f191461031257806341e1f7811461036c57806366188463146103955780636a5e2650146103ef57806370a082311461041c5780637d64bcb4146104695780638da5cb5b1461049657806395d89b41146104eb578063a9059cbb14610579578063c7ec3be2146105d3578063d73dd6231461062d578063dd62ed3e14610687578063f2fde38b146106f3575b600080fd5b341561012257600080fd5b61012a61072c565b604051808215151515815260200191505060405180910390f35b341561014f57600080fd5b61015761073f565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561019757808201518184015260208101905061017c565b50505050905090810190601f1680156101c45780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101dd57600080fd5b610212600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610778565b604051808215151515815260200191505060405180910390f35b341561023757600080fd5b61023f6107a7565b6040518082815260200191505060405180910390f35b341561026057600080fd5b6102686107ad565b005b341561027557600080fd5b6102c9600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803590602001909190505061086e565b604051808215151515815260200191505060405180910390f35b34156102ee57600080fd5b6102f661089f565b604051808260ff1660ff16815260200191505060405180910390f35b341561031d57600080fd5b610352600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919080359060200190919050506108a4565b604051808215151515815260200191505060405180910390f35b341561037757600080fd5b61037f610934565b6040518082815260200191505060405180910390f35b34156103a057600080fd5b6103d5600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610945565b604051808215151515815260200191505060405180910390f35b34156103fa57600080fd5b610402610974565b604051808215151515815260200191505060405180910390f35b341561042757600080fd5b610453600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610987565b6040518082815260200191505060405180910390f35b341561047457600080fd5b61047c6109d0565b604051808215151515815260200191505060405180910390f35b34156104a157600080fd5b6104a9610a98565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156104f657600080fd5b6104fe610abe565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561053e578082015181840152602081019050610523565b50505050905090810190601f16801561056b5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561058457600080fd5b6105b9600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610af7565b604051808215151515815260200191505060405180910390f35b34156105de57600080fd5b610613600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610b26565b604051808215151515815260200191505060405180910390f35b341561063857600080fd5b61066d600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610b96565b604051808215151515815260200191505060405180910390f35b341561069257600080fd5b6106dd600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610bc5565b6040518082815260200191505060405180910390f35b34156106fe57600080fd5b61072a600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610c4c565b005b600360149054906101000a900460ff1681565b6040805190810160405280600b81526020017f44436c656172546f6b656e00000000000000000000000000000000000000000081525081565b6000600360159054906101000a900460ff16151561079557600080fd5b61079f8383610da4565b905092915050565b60005481565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561080957600080fd5b600360159054906101000a900460ff1615151561082557600080fd5b6001600360156101000a81548160ff0219169083151502179055507f8a8c1d49e289f119bff9803579c0e72a9ad347ef85c0d07d867af78b94039c6360405160405180910390a1565b6000600360159054906101000a900460ff16151561088b57600080fd5b610896848484610e96565b90509392505050565b601281565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561090257600080fd5b601260ff16600a0a633b9aca000282600054011115151561092257600080fd5b61092c8383611255565b905092915050565b601260ff16600a0a633b9aca000281565b6000600360159054906101000a900460ff16151561096257600080fd5b61096c838361143d565b905092915050565b600360159054906101000a900460ff1681565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610a2e57600080fd5b600360149054906101000a900460ff16151515610a4a57600080fd5b6001600360146101000a81548160ff0219169083151502179055507fae5184fba832cb2b1f702aca6117b8d265eaf03ad33eb133f19dde0f5920fa0860405160405180910390a16001905090565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6040805190810160405280600381526020017f444348000000000000000000000000000000000000000000000000000000000081525081565b6000600360159054906101000a900460ff161515610b1457600080fd5b610b1e83836116ce565b905092915050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610b8457600080fd5b610b8e83836118f2565b905092915050565b6000600360159054906101000a900460ff161515610bb357600080fd5b610bbd8383611abe565b905092915050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141515610ca857600080fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515610ce457600080fd5b8073ffffffffffffffffffffffffffffffffffffffff16600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a380600360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600081600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040518082815260200191505060405180910390a36001905092915050565b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614151515610ed357600080fd5b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548211151515610f2157600080fd5b600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548211151515610fac57600080fd5b610ffe82600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061109382600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061116582600260008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a3600190509392505050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161415156112b357600080fd5b600360149054906101000a900460ff161515156112cf57600080fd5b6112e482600054611cd390919063ffffffff16565b60008190555061133c82600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff167f0f6798a560793a54c3bcfe86a93cde1e73087d944c0ea20544137d4121396885836040518082815260200191505060405180910390a28273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b600080600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508083111561154e576000600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055506115e2565b6115618382611cba90919063ffffffff16565b600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055505b8373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546040518082815260200191505060405180910390a3600191505092915050565b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415151561170b57600080fd5b600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054821115151561175957600080fd5b6117ab82600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cba90919063ffffffff16565b600160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555061184082600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b6000600360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561195057600080fd5b61196582600054611cd390919063ffffffff16565b6000819055506119bd82600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff167f0f6798a560793a54c3bcfe86a93cde1e73087d944c0ea20544137d4121396885836040518082815260200191505060405180910390a28273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a36001905092915050565b6000611b4f82600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611cd390919063ffffffff16565b600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546040518082815260200191505060405180910390a36001905092915050565b6000828211151515611cc857fe5b818303905092915050565b6000808284019050838110151515611ce757fe5b80915050929150505600a165627a7a72305820423cd54259ced0826a49d40582ce142ea68b743390963fd72d9de9a4cb70044b0029
Deployed Bytecode Sourcemap
16797:1954:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15395:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16840:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:2;8:100;;;99:1;94:3;90;84:5;80:1;75:3;71;64:6;52:2;49:1;45:3;40:15;;8:100;;;12:14;3:109;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18159:144:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9914:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17633:122;;;;;;;;;;;;;;17989:164;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16930:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17318:171;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16972:92;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18567:179;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17139:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11396:109;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16651:139;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16888:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:2;8:100;;;99:1;94:3;90;84:5;80:1;75:3;71;64:6;52:2;49:1;45:3;40:15;;8:100;;;12:14;3:109;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17847:136:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17497:130;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18392:169;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13515:128;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;672:173;;;;;;;;;;;;;;;;;;;;;;;;;;;;15395:35;;;;;;;;;;;;;:::o;16840:43::-;;;;;;;;;;;;;;;;;;;;:::o;18159:144::-;18224:4;18245:8;;;;;;;;;;;18237:17;;;;;;;;18268:29;18282:7;18291:5;18268:13;:29::i;:::-;18261:36;;18159:144;;;;:::o;9914:26::-;;;;:::o;17633:122::-;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;17690:8;;;;;;;;;;;17689:9;17680:19;;;;;;;;17717:4;17706:8;;:15;;;;;;;;;;;;;;;;;;17728:21;;;;;;;;;;17633:122::o;17989:164::-;18068:4;18089:8;;;;;;;;;;;18081:17;;;;;;;;18112:35;18131:4;18137:2;18141:5;18112:18;:35::i;:::-;18105:42;;17989:164;;;;;:::o;16930:35::-;16963:2;16930:35;:::o;17318:171::-;17386:4;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;16963:2;17046:17;;17040:2;:23;17014:22;:50;17421:6;17407:11;;:20;:39;;17399:48;;;;;;;;17461:22;17472:2;17476:6;17461:10;:22::i;:::-;17454:29;;17318:171;;;;:::o;16972:92::-;16963:2;17046:17;;17040:2;:23;17014:22;:50;16972:92;:::o;18567:179::-;18648:4;18669:8;;;;;;;;;;;18661:17;;;;;;;;18692:48;18715:7;18724:15;18692:22;:48::i;:::-;18685:55;;18567:179;;;;:::o;17139:28::-;;;;;;;;;;;;;:::o;11396:109::-;11452:15;11483:8;:16;11492:6;11483:16;;;;;;;;;;;;;;;;11476:23;;11396:109;;;:::o;16651:139::-;16710:4;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;15474:15;;;;;;;;;;;15473:16;15465:25;;;;;;;;16741:4;16723:15;;:22;;;;;;;;;;;;;;;;;;16752:14;;;;;;;;;;16780:4;16773:11;;16651:139;:::o;50:20::-;;;;;;;;;;;;;:::o;16888:37::-;;;;;;;;;;;;;;;;;;;;:::o;17847:136::-;17908:4;17929:8;;;;;;;;;;;17921:17;;;;;;;;17952:25;17967:2;17971:5;17952:14;:25::i;:::-;17945:32;;17847:136;;;;:::o;17497:130::-;17572:4;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;17592:29;17610:2;17614:6;17592:17;:29::i;:::-;17585:36;;17497:130;;;;:::o;18392:169::-;18468:4;18489:8;;;;;;;;;;;18481:17;;;;;;;;18512:43;18535:7;18544:10;18512:22;:43::i;:::-;18505:50;;18392:169;;;;:::o;13515:128::-;13589:7;13612;:15;13620:6;13612:15;;;;;;;;;;;;;;;:25;13628:8;13612:25;;;;;;;;;;;;;;;;13605:32;;13515:128;;;;:::o;672:173::-;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;769:1;749:22;;:8;:22;;;;741:31;;;;;;;;807:8;779:37;;800:5;;;;;;;;;;;779:37;;;;;;;;;;;;831:8;823:5;;:16;;;;;;;;;;;;;;;;;;672:173;:::o;13001:187::-;13068:4;13113:6;13081:7;:19;13089:10;13081:19;;;;;;;;;;;;;;;:29;13101:8;13081:29;;;;;;;;;;;;;;;:38;;;;13147:8;13126:38;;13135:10;13126:38;;;13157:6;13126:38;;;;;;;;;;;;;;;;;;13178:4;13171:11;;13001:187;;;;:::o;11917:449::-;11999:4;12035:1;12020:17;;:3;:17;;;;12012:26;;;;;;;;12063:8;:15;12072:5;12063:15;;;;;;;;;;;;;;;;12053:6;:25;;12045:34;;;;;;;;12104:7;:14;12112:5;12104:14;;;;;;;;;;;;;;;:26;12119:10;12104:26;;;;;;;;;;;;;;;;12094:6;:36;;12086:45;;;;;;;;12158:27;12178:6;12158:8;:15;12167:5;12158:15;;;;;;;;;;;;;;;;:19;;:27;;;;:::i;:::-;12140:8;:15;12149:5;12140:15;;;;;;;;;;;;;;;:45;;;;12208:25;12226:6;12208:8;:13;12217:3;12208:13;;;;;;;;;;;;;;;;:17;;:25;;;;:::i;:::-;12192:8;:13;12201:3;12192:13;;;;;;;;;;;;;;;:41;;;;12269:38;12300:6;12269:7;:14;12277:5;12269:14;;;;;;;;;;;;;;;:26;12284:10;12269:26;;;;;;;;;;;;;;;;:30;;:38;;;;:::i;:::-;12240:7;:14;12248:5;12240:14;;;;;;;;;;;;;;;:26;12255:10;12240:26;;;;;;;;;;;;;;;:67;;;;12330:3;12314:28;;12323:5;12314:28;;;12335:6;12314:28;;;;;;;;;;;;;;;;;;12356:4;12349:11;;11917:449;;;;;:::o;15748:268::-;15826:4;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;15474:15;;;;;;;;;;;15473:16;15465:25;;;;;;;;15853:24;15869:7;15853:11;;:15;;:24;;;;:::i;:::-;15839:11;:38;;;;15900:26;15918:7;15900:8;:13;15909:3;15900:13;;;;;;;;;;;;;;;;:17;;:26;;;;:::i;:::-;15884:8;:13;15893:3;15884:13;;;;;;;;;;;;;;;:42;;;;15938:3;15933:18;;;15943:7;15933:18;;;;;;;;;;;;;;;;;;15979:3;15958:34;;15975:1;15958:34;;;15984:7;15958:34;;;;;;;;;;;;;;;;;;16006:4;15999:11;;15748:268;;;;:::o;14847:407::-;14930:4;14943:13;14959:7;:19;14967:10;14959:19;;;;;;;;;;;;;;;:29;14979:8;14959:29;;;;;;;;;;;;;;;;14943:45;;15018:8;14999:16;:27;14995:168;;;15069:1;15037:7;:19;15045:10;15037:19;;;;;;;;;;;;;;;:29;15057:8;15037:29;;;;;;;;;;;;;;;:33;;;;14995:168;;;15125:30;15138:16;15125:8;:12;;:30;;;;:::i;:::-;15093:7;:19;15101:10;15093:19;;;;;;;;;;;;;;;:29;15113:8;15093:29;;;;;;;;;;;;;;;:62;;;;14995:168;15190:8;15169:61;;15178:10;15169:61;;;15200:7;:19;15208:10;15200:19;;;;;;;;;;;;;;;:29;15220:8;15200:29;;;;;;;;;;;;;;;;15169:61;;;;;;;;;;;;;;;;;;15244:4;15237:11;;14847:407;;;;;:::o;10799:388::-;10862:4;10898:1;10883:17;;:3;:17;;;;10875:26;;;;;;;;10926:8;:20;10935:10;10926:20;;;;;;;;;;;;;;;;10916:6;:30;;10908:39;;;;;;;;11043:32;11068:6;11043:8;:20;11052:10;11043:20;;;;;;;;;;;;;;;;:24;;:32;;;;:::i;:::-;11020:8;:20;11029:10;11020:20;;;;;;;;;;;;;;;:55;;;;11098:25;11116:6;11098:8;:13;11107:3;11098:13;;;;;;;;;;;;;;;;:17;;:25;;;;:::i;:::-;11082:8;:13;11091:3;11082:13;;;;;;;;;;;;;;;:41;;;;11151:3;11130:33;;11139:10;11130:33;;;11156:6;11130:33;;;;;;;;;;;;;;;;;;11177:4;11170:11;;10799:388;;;;:::o;16264:267::-;16341:4;483:5;;;;;;;;;;;469:19;;:10;:19;;;461:28;;;;;;;;16368:24;16384:7;16368:11;;:15;;:24;;;;:::i;:::-;16354:11;:38;;;;16415:26;16433:7;16415:8;:13;16424:3;16415:13;;;;;;;;;;;;;;;;:17;;:26;;;;:::i;:::-;16399:8;:13;16408:3;16399:13;;;;;;;;;;;;;;;:42;;;;16453:3;16448:18;;;16458:7;16448:18;;;;;;;;;;;;;;;;;;16494:3;16473:34;;16490:1;16473:34;;;16499:7;16473:34;;;;;;;;;;;;;;;;;;16521:4;16514:11;;16264:267;;;;:::o;14112:261::-;14190:4;14235:46;14269:11;14235:7;:19;14243:10;14235:19;;;;;;;;;;;;;;;:29;14255:8;14235:29;;;;;;;;;;;;;;;;:33;;:46;;;;:::i;:::-;14203:7;:19;14211:10;14203:19;;;;;;;;;;;;;;;:29;14223:8;14203:29;;;;;;;;;;;;;;;:78;;;;14309:8;14288:61;;14297:10;14288:61;;;14319:7;:19;14327:10;14319:19;;;;;;;;;;;;;;;:29;14339:8;14319:29;;;;;;;;;;;;;;;;14288:61;;;;;;;;;;;;;;;;;;14363:4;14356:11;;14112:261;;;;:::o;4296:113::-;4354:7;4382:1;4377;:6;;4370:14;;;;;;4402:1;4398;:5;4391:12;;4296:113;;;;:::o;4415:133::-;4473:7;4489:9;4505:1;4501;:5;4489:17;;4525:1;4520;:6;;4513:14;;;;;;4541:1;4534:8;;4415:133;;;;;:::o
Swarm Source
bzzr://423cd54259ced0826a49d40582ce142ea68b743390963fd72d9de9a4cb70044b
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.