Warning! Contract bytecode has been changed and doesn't match the verified one. Therefore, interaction with this smart contract may be risky.
This contract has been partially verified via Sourcify.
View contract in Sourcify repository
- Contract name:
- UpCrowdPoolingFactory
- Optimization enabled
- true
- Compiler version
- v0.6.9+commit.3e3065ac
- Optimization runs
- 200
- EVM Version
- istanbul
- Verified at
- 2026-04-18T21:35:06.716017Z
Constructor Arguments
0000000000000000000000005e5a7b76462e4bdf83aa98795644281bdba80b88000000000000000000000000327344b382ee1b44fb0a72945fcdcc7243200dd700000000000000000000000072d220ce168c4f361dd4dee5d826a01ad8598f6c00000000000000000000000095c4f5b83aa70810d4f142d58e5f7242bd891cb00000000000000000000000005e84190a270333ace5b9202a3f4cebf11b81bb010000000000000000000000006b208e08dcf6bd51f50c5da09d15b2d8e5c46cf2
Arg [0] (address) : 0x5e5a7b76462e4bdf83aa98795644281bdba80b88
Arg [1] (address) : 0x327344b382ee1b44fb0a72945fcdcc7243200dd7
Arg [2] (address) : 0x72d220ce168c4f361dd4dee5d826a01ad8598f6c
Arg [3] (address) : 0x95c4f5b83aa70810d4f142d58e5f7242bd891cb0
Arg [4] (address) : 0x5e84190a270333ace5b9202a3f4cebf11b81bb01
Arg [5] (address) : 0x6b208e08dcf6bd51f50c5da09d15b2d8e5c46cf2
UpCrowdPoolingFactory.sol
// File: contracts/lib/InitializableOwnable.sol
/*
Copyright 2020 DODO ZOO.
SPDX-License-Identifier: Apache-2.0
*/
pragma solidity 0.6.9;
pragma experimental ABIEncoderV2;
/**
* @title Ownable
* @author DODO Breeder
*
* @notice Ownership related functions
*/
contract InitializableOwnable {
address public _OWNER_;
address public _NEW_OWNER_;
bool internal _INITIALIZED_;
// ============ Events ============
event OwnershipTransferPrepared(address indexed previousOwner, address indexed newOwner);
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
// ============ Modifiers ============
modifier notInitialized() {
require(!_INITIALIZED_, "DODO_INITIALIZED");
_;
}
modifier onlyOwner() {
require(msg.sender == _OWNER_, "NOT_OWNER");
_;
}
// ============ Functions ============
function initOwner(address newOwner) public notInitialized {
_INITIALIZED_ = true;
_OWNER_ = newOwner;
}
function transferOwnership(address newOwner) public onlyOwner {
emit OwnershipTransferPrepared(_OWNER_, newOwner);
_NEW_OWNER_ = newOwner;
}
function claimOwnership() public {
require(msg.sender == _NEW_OWNER_, "INVALID_CLAIM");
emit OwnershipTransferred(_OWNER_, _NEW_OWNER_);
_OWNER_ = _NEW_OWNER_;
_NEW_OWNER_ = address(0);
}
}
// File: contracts/lib/CloneFactory.sol
interface ICloneFactory {
function clone(address prototype) external returns (address proxy);
}
// introduction of proxy mode design: https://docs.openzeppelin.com/upgrades/2.8/
// minimum implementation of transparent proxy: https://eips.ethereum.org/EIPS/eip-1167
contract CloneFactory is ICloneFactory {
function clone(address prototype) external override returns (address proxy) {
bytes20 targetBytes = bytes20(prototype);
assembly {
let clone := mload(0x40)
mstore(clone, 0x3d602d80600a3d3981f3363d3d373d3d3d363d73000000000000000000000000)
mstore(add(clone, 0x14), targetBytes)
mstore(
add(clone, 0x28),
0x5af43d82803e903d91602b57fd5bf30000000000000000000000000000000000
)
proxy := create(0, clone, 0x37)
}
return proxy;
}
}
// File: contracts/CrowdPooling/intf/ICP.sol
interface ICP {
function init(
address[] calldata addressList,
uint256[] calldata timeLine,
uint256[] calldata valueList,
bool isOpenTWAP
) external;
function bid(address to) external;
function cancel(address assetTo, uint256 amount) external;
function settle() external;
function emergencySettle() external;
function claimBase() external;
function claimQuote() external;
function claimLPToken() external;
}
// File: contracts/lib/SafeMath.sol
/**
* @title SafeMath
* @author DODO Breeder
*
* @notice Math operations with safety checks that revert on error
*/
library SafeMath {
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b, "MUL_ERROR");
return c;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
require(b > 0, "DIVIDING_ERROR");
return a / b;
}
function divCeil(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 quotient = div(a, b);
uint256 remainder = a - quotient * b;
if (remainder > 0) {
return quotient + 1;
} else {
return quotient;
}
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
require(b <= a, "SUB_ERROR");
return a - b;
}
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "ADD_ERROR");
return c;
}
function sqrt(uint256 x) internal pure returns (uint256 y) {
uint256 z = x / 2 + 1;
y = x;
while (z < y) {
y = z;
z = (x / z + z) / 2;
}
}
}
// File: contracts/intf/IERC20.sol
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @dev Returns the amount of tokens in existence.
*/
function totalSupply() external view returns (uint256);
function decimals() external view returns (uint8);
function name() external view returns (string memory);
function symbol() external view returns (string memory);
/**
* @dev Returns the amount of tokens owned by `account`.
*/
function balanceOf(address account) external view returns (uint256);
/**
* @dev Moves `amount` tokens from the caller's account to `recipient`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address recipient, uint256 amount) external returns (bool);
/**
* @dev Returns the remaining number of tokens that `spender` will be
* allowed to spend on behalf of `owner` through {transferFrom}. This is
* zero by default.
*
* This value changes when {approve} or {transferFrom} are called.
*/
function allowance(address owner, address spender) external view returns (uint256);
/**
* @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* IMPORTANT: 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
*
* Emits an {Approval} event.
*/
function approve(address spender, uint256 amount) external returns (bool);
/**
* @dev Moves `amount` tokens from `sender` to `recipient` using the
* allowance mechanism. `amount` is then deducted from the caller's
* allowance.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool);
}
// File: contracts/lib/DecimalMath.sol
/**
* @title DecimalMath
* @author DODO Breeder
*
* @notice Functions for fixed point number with 18 decimals
*/
library DecimalMath {
using SafeMath for uint256;
uint256 internal constant ONE = 10**18;
uint256 internal constant ONE2 = 10**36;
function mulFloor(uint256 target, uint256 d) internal pure returns (uint256) {
return target.mul(d) / (10**18);
}
function mulCeil(uint256 target, uint256 d) internal pure returns (uint256) {
return target.mul(d).divCeil(10**18);
}
function divFloor(uint256 target, uint256 d) internal pure returns (uint256) {
return target.mul(10**18).div(d);
}
function divCeil(uint256 target, uint256 d) internal pure returns (uint256) {
return target.mul(10**18).divCeil(d);
}
function reciprocalFloor(uint256 target) internal pure returns (uint256) {
return uint256(10**36).div(target);
}
function reciprocalCeil(uint256 target) internal pure returns (uint256) {
return uint256(10**36).divCeil(target);
}
}
// File: contracts/Factory/UpCrowdPoolingFactory.sol
/**
* @title UpCrowdPoolingFacotry
* @author DODO Breeder
*
* @notice Create And Register vary price CP Pools
*/
contract UpCrowdPoolingFactory is InitializableOwnable {
using SafeMath for uint256;
// ============ Templates ============
address public immutable _CLONE_FACTORY_;
address public immutable _DVM_FACTORY_;
address public immutable _DEFAULT_MAINTAINER_;
address public immutable _DEFAULT_MT_FEE_RATE_MODEL_;
address public immutable _DEFAULT_PERMISSION_MANAGER_;
address public _CP_TEMPLATE_;
// ============ Settings =============
uint256 public _FREEZE_DURATION_ = 30 days;
uint256 public _CALM_DURATION_ = 0;
uint256 public _VEST_DURATION_ = 0;
uint256 public _CLIFF_RATE_ = 10**18;
// ============ Registry ============
// base -> quote -> CP address list
mapping(address => mapping(address => address[])) public _REGISTRY_;
// creator -> CP address list
mapping(address => address[]) public _USER_REGISTRY_;
// ============ modifiers ===========
modifier valueCheck(
address cpAddress,
address baseToken,
uint256[] memory timeLine,
uint256[] memory valueList)
{
require(timeLine[2] <= _CALM_DURATION_, "CP_FACTORY : PHASE_CALM_DURATION_INVALID");
require(timeLine[4] == _VEST_DURATION_, "CP_FACTORY : VEST_DURATION_INVALID");
require(valueList[3] == _CLIFF_RATE_, "CP_FACTORY : CLIFF_RATE_INVALID");
require(timeLine[3] >= _FREEZE_DURATION_, "CP_FACTORY : FREEZE_DURATION_INVALID");
_;
}
// ============ Events ============
event NewCP(
address baseToken,
address quoteToken,
address creator,
address cp
);
constructor(
address cloneFactory,
address cpTemplate,
address dvmFactory,
address defaultMaintainer,
address defaultMtFeeRateModel,
address defaultPermissionManager
) public {
_CLONE_FACTORY_ = cloneFactory;
_CP_TEMPLATE_ = cpTemplate;
_DVM_FACTORY_ = dvmFactory;
_DEFAULT_MAINTAINER_ = defaultMaintainer;
_DEFAULT_MT_FEE_RATE_MODEL_ = defaultMtFeeRateModel;
_DEFAULT_PERMISSION_MANAGER_ = defaultPermissionManager;
}
// ============ Functions ============
function createCrowdPooling() external returns (address newCrowdPooling) {
newCrowdPooling = ICloneFactory(_CLONE_FACTORY_).clone(_CP_TEMPLATE_);
}
function initCrowdPooling(
address cpAddress,
address creator,
address baseToken,
address quoteToken,
uint256[] memory timeLine,
uint256[] memory valueList,
bool isOpenTWAP
) external valueCheck(cpAddress,baseToken,timeLine,valueList) {
{
address[] memory addressList = new address[](7);
addressList[0] = creator;
addressList[1] = _DEFAULT_MAINTAINER_;
addressList[2] = baseToken;
addressList[3] = quoteToken;
addressList[4] = _DEFAULT_PERMISSION_MANAGER_;
addressList[5] = _DEFAULT_MT_FEE_RATE_MODEL_;
addressList[6] = _DVM_FACTORY_;
if(valueList[0] == 0) valueList[0] = uint112(-1);
ICP(cpAddress).init(
addressList,
timeLine,
valueList,
isOpenTWAP
);
}
_REGISTRY_[baseToken][quoteToken].push(cpAddress);
_USER_REGISTRY_[creator].push(cpAddress);
emit NewCP(baseToken, quoteToken, creator, cpAddress);
}
// ============ View Functions ============
function getCrowdPooling(address baseToken, address quoteToken)
external
view
returns (address[] memory pools)
{
return _REGISTRY_[baseToken][quoteToken];
}
function getCrowdPoolingBidirection(address token0, address token1)
external
view
returns (address[] memory baseToken0Pools, address[] memory baseToken1Pools)
{
return (_REGISTRY_[token0][token1], _REGISTRY_[token1][token0]);
}
function getCrowdPoolingByUser(address user)
external
view
returns (address[] memory pools)
{
return _USER_REGISTRY_[user];
}
// ============ Owner Functions ============
function updateCPTemplate(address _newCPTemplate) external onlyOwner {
_CP_TEMPLATE_ = _newCPTemplate;
}
function setFreezeDuration(uint256 _newFreeDuration) public onlyOwner {
_FREEZE_DURATION_ = _newFreeDuration;
}
function setCalmDuration(uint256 _newCalmDuration) public onlyOwner {
_CALM_DURATION_ = _newCalmDuration;
}
function setVestDuration(uint256 _newVestDuration) public onlyOwner {
_VEST_DURATION_ = _newVestDuration;
}
function setCliffRate(uint256 _newCliffRate) public onlyOwner {
require(_newCliffRate <= 10**18, "CP_FACTORY : INVALID");
_CLIFF_RATE_ = _newCliffRate;
}
}
Compiler Settings
{"remappings":[],"optimizer":{"runs":200,"enabled":true},"metadata":{"bytecodeHash":"ipfs"},"libraries":{},"evmVersion":"istanbul","compilationTarget":{"UpCrowdPoolingFactory.sol":"UpCrowdPoolingFactory"}}
Contract ABI
[{"type":"constructor","stateMutability":"nonpayable","inputs":[{"type":"address","name":"cloneFactory","internalType":"address"},{"type":"address","name":"cpTemplate","internalType":"address"},{"type":"address","name":"dvmFactory","internalType":"address"},{"type":"address","name":"defaultMaintainer","internalType":"address"},{"type":"address","name":"defaultMtFeeRateModel","internalType":"address"},{"type":"address","name":"defaultPermissionManager","internalType":"address"}]},{"type":"event","name":"NewCP","inputs":[{"type":"address","name":"baseToken","internalType":"address","indexed":false},{"type":"address","name":"quoteToken","internalType":"address","indexed":false},{"type":"address","name":"creator","internalType":"address","indexed":false},{"type":"address","name":"cp","internalType":"address","indexed":false}],"anonymous":false},{"type":"event","name":"OwnershipTransferPrepared","inputs":[{"type":"address","name":"previousOwner","internalType":"address","indexed":true},{"type":"address","name":"newOwner","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"OwnershipTransferred","inputs":[{"type":"address","name":"previousOwner","internalType":"address","indexed":true},{"type":"address","name":"newOwner","internalType":"address","indexed":true}],"anonymous":false},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_CALM_DURATION_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_CLIFF_RATE_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_CLONE_FACTORY_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_CP_TEMPLATE_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_DEFAULT_MAINTAINER_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_DEFAULT_MT_FEE_RATE_MODEL_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_DEFAULT_PERMISSION_MANAGER_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_DVM_FACTORY_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_FREEZE_DURATION_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_NEW_OWNER_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_OWNER_","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_REGISTRY_","inputs":[{"type":"address","name":"","internalType":"address"},{"type":"address","name":"","internalType":"address"},{"type":"uint256","name":"","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"_USER_REGISTRY_","inputs":[{"type":"address","name":"","internalType":"address"},{"type":"uint256","name":"","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_VEST_DURATION_","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"claimOwnership","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"address","name":"newCrowdPooling","internalType":"address"}],"name":"createCrowdPooling","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address[]","name":"pools","internalType":"address[]"}],"name":"getCrowdPooling","inputs":[{"type":"address","name":"baseToken","internalType":"address"},{"type":"address","name":"quoteToken","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address[]","name":"baseToken0Pools","internalType":"address[]"},{"type":"address[]","name":"baseToken1Pools","internalType":"address[]"}],"name":"getCrowdPoolingBidirection","inputs":[{"type":"address","name":"token0","internalType":"address"},{"type":"address","name":"token1","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address[]","name":"pools","internalType":"address[]"}],"name":"getCrowdPoolingByUser","inputs":[{"type":"address","name":"user","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"initCrowdPooling","inputs":[{"type":"address","name":"cpAddress","internalType":"address"},{"type":"address","name":"creator","internalType":"address"},{"type":"address","name":"baseToken","internalType":"address"},{"type":"address","name":"quoteToken","internalType":"address"},{"type":"uint256[]","name":"timeLine","internalType":"uint256[]"},{"type":"uint256[]","name":"valueList","internalType":"uint256[]"},{"type":"bool","name":"isOpenTWAP","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"initOwner","inputs":[{"type":"address","name":"newOwner","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setCalmDuration","inputs":[{"type":"uint256","name":"_newCalmDuration","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setCliffRate","inputs":[{"type":"uint256","name":"_newCliffRate","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setFreezeDuration","inputs":[{"type":"uint256","name":"_newFreeDuration","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setVestDuration","inputs":[{"type":"uint256","name":"_newVestDuration","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"transferOwnership","inputs":[{"type":"address","name":"newOwner","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateCPTemplate","inputs":[{"type":"address","name":"_newCPTemplate","internalType":"address"}]}]
Contract Creation Code
0x61012060405262278d0060035560006004556000600555670de0b6b3a76400006006553480156200002f57600080fd5b5060405162001605380380620016058339810160408190526200005291620000ca565b606095861b6001600160601b0319908116608052600280546001600160a01b0319166001600160a01b03979097169690961790955592851b841660a05290841b831660c052831b821660e05290911b166101005262000150565b80516001600160a01b0381168114620000c457600080fd5b92915050565b60008060008060008060c08789031215620000e3578182fd5b620000ef8888620000ac565b9550620001008860208901620000ac565b9450620001118860408901620000ac565b9350620001228860608901620000ac565b9250620001338860808901620000ac565b9150620001448860a08901620000ac565b90509295509295509295565b60805160601c60a05160601c60c05160601c60e05160601c6101005160601c61144d620001b8600039806109415280610b5f5250806107095280610bad52508061075c5280610ab55250806106e55280610bfb5250806107aa5280610965525061144d6000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c80636ca2aa95116100f9578063bdeb0a9111610097578063e0f5d89e11610071578063e0f5d89e1461031f578063eb774d0514610327578063ecfc2db01461032f578063f2fde38b14610342576101a9565b8063bdeb0a91146102fc578063c2c2757b1461030f578063ce90ea7414610317576101a9565b806389edcf14116100d357806389edcf14146102c6578063a58888db146102ce578063a6569b3f146102e1578063a820636b146102e9576101a9565b80636ca2aa95146102a357806381ab4d0a146102b65780638456db15146102be576101a9565b80634c59de661161016657806364ddb0131161014057806364ddb013146102605780636556c7e51461027357806369e4e417146102935780636c5ccb9b1461029b576101a9565b80634c59de66146102325780634e71e0c8146102455780635568587a1461024d576101a9565b806307b8a636146101ae5780630d009297146101c357806316048bc4146101d6578063294dafc0146101f45780633ff9b61e1461020957806341a1759c14610211575b600080fd5b6101c16101bc3660046110f9565b610355565b005b6101c16101d1366004610f53565b61038d565b6101de6103ed565b6040516101eb9190611183565b60405180910390f35b6101fc6103fc565b6040516101eb91906113f6565b6101fc610402565b61022461021f366004610f92565b610408565b6040516101eb9291906111d5565b6101c16102403660046110f9565b610500565b6101c1610557565b6101c161025b3660046110f9565b6105e5565b6101c161026e366004610f53565b610614565b610286610281366004610f92565b610660565b6040516101eb91906111c2565b6101de6106e3565b6101de610707565b6101c16102b13660046110f9565b61072b565b6101de61075a565b6101de61077e565b6101de61078d565b6101de6102dc3660046110ce565b610837565b6101de61086c565b6102866102f7366004610f53565b61087b565b6101de61030a36600461108e565b6108f1565b6101fc610933565b6101fc610939565b6101de61093f565b6101de610963565b6101c161033d366004610fca565b610987565b6101c1610350366004610f53565b610e3b565b6000546001600160a01b031633146103885760405162461bcd60e51b815260040161037f906113d3565b60405180910390fd5b600455565b600154600160a01b900460ff16156103b75760405162461bcd60e51b815260040161037f906113a9565b6001805460ff60a01b1916600160a01b179055600080546001600160a01b039092166001600160a01b0319909216919091179055565b6000546001600160a01b031681565b60065481565b60055481565b6001600160a01b038083166000818152600760208181526040808420958716845294815284832091815284832093835292835290839020815484518185028101850190955280855260609485949091849183018282801561049257602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311610474575b50505050509150808054806020026020016040519081016040528092919081815260200182805480156104ee57602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116104d0575b50505050509050915091509250929050565b6000546001600160a01b0316331461052a5760405162461bcd60e51b815260040161037f906113d3565b670de0b6b3a76400008111156105525760405162461bcd60e51b815260040161037f9061124f565b600655565b6001546001600160a01b031633146105815760405162461bcd60e51b815260040161037f9061127d565b600154600080546040516001600160a01b0393841693909116917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a360018054600080546001600160a01b03199081166001600160a01b03841617909155169055565b6000546001600160a01b0316331461060f5760405162461bcd60e51b815260040161037f906113d3565b600555565b6000546001600160a01b0316331461063e5760405162461bcd60e51b815260040161037f906113d3565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0380831660009081526007602090815260408083209385168352928152908290208054835181840281018401909452808452606093928301828280156106d657602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116106b8575b5050505050905092915050565b7f000000000000000000000000000000000000000000000000000000000000000081565b7f000000000000000000000000000000000000000000000000000000000000000081565b6000546001600160a01b031633146107555760405162461bcd60e51b815260040161037f906113d3565b600355565b7f000000000000000000000000000000000000000000000000000000000000000081565b6001546001600160a01b031681565b6002546040516340925bc760e11b81526000916001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000811692638124b78e926107e0921690600401611183565b602060405180830381600087803b1580156107fa57600080fd5b505af115801561080e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108329190610f76565b905090565b6008602052816000526040600020818154811061085057fe5b6000918252602090912001546001600160a01b03169150829050565b6002546001600160a01b031681565b6001600160a01b0381166000908152600860209081526040918290208054835181840281018401909452808452606093928301828280156108e557602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116108c7575b50505050509050919050565b6007602052826000526040600020602052816000526040600020818154811061091657fe5b6000918252602090912001546001600160a01b0316925083915050565b60045481565b60035481565b7f000000000000000000000000000000000000000000000000000000000000000081565b7f000000000000000000000000000000000000000000000000000000000000000081565b868584846004548260028151811061099b57fe5b602002602001015111156109c15760405162461bcd60e51b815260040161037f9061131f565b600554826004815181106109d157fe5b6020026020010151146109f65760405162461bcd60e51b815260040161037f90611367565b60065481600381518110610a0657fe5b602002602001015114610a2b5760405162461bcd60e51b815260040161037f906112e8565b60035482600381518110610a3b57fe5b60200260200101511015610a615760405162461bcd60e51b815260040161037f906112a4565b60408051600780825261010082019092526060916020820160e0803683370190505090508a81600081518110610a9357fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600181518110610ae157fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508981600281518110610b0f57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508881600381518110610b3d57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600481518110610b8b57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600581518110610bd957fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600681518110610c2757fe5b60200260200101906001600160a01b031690816001600160a01b03168152505086600081518110610c5457fe5b602002602001015160001415610c91576000196dffffffffffffffffffffffffffff1687600081518110610c8457fe5b6020026020010181815250505b6040516341dd3c3360e11b81526001600160a01b038d16906383ba786690610cc39084908c908c908c90600401611203565b600060405180830381600087803b158015610cdd57600080fd5b505af1158015610cf1573d6000803e3d6000fd5b5050505050600760008a6001600160a01b03166001600160a01b031681526020019081526020016000206000896001600160a01b03166001600160a01b031681526020019081526020016000208b9080600181540180825580915050600190039060005260206000200160009091909190916101000a8154816001600160a01b0302191690836001600160a01b03160217905550600860008b6001600160a01b03166001600160a01b031681526020019081526020016000208b9080600181540180825580915050600190039060005260206000200160009091909190916101000a8154816001600160a01b0302191690836001600160a01b031602179055507f0bd1e8ce555b4ec75d8b1c8113a8812659e0d94f0b4c67637dc049434604b45d89898c8e604051610e269493929190611197565b60405180910390a15050505050505050505050565b6000546001600160a01b03163314610e655760405162461bcd60e51b815260040161037f906113d3565b600080546040516001600160a01b03808516939216917fdcf55418cee3220104fef63f979ff3c4097ad240c0c43dcb33ce837748983e6291a3600180546001600160a01b0319166001600160a01b0392909216919091179055565b600082601f830112610ed0578081fd5b813567ffffffffffffffff80821115610ee7578283fd5b602080830260405182828201018181108582111715610f04578687fd5b604052848152945081850192508582018187018301881015610f2557600080fd5b600091505b84821015610f48578035845292820192600191909101908201610f2a565b505050505092915050565b600060208284031215610f64578081fd5b8135610f6f816113ff565b9392505050565b600060208284031215610f87578081fd5b8151610f6f816113ff565b60008060408385031215610fa4578081fd5b8235610faf816113ff565b91506020830135610fbf816113ff565b809150509250929050565b600080600080600080600060e0888a031215610fe4578283fd5b8735610fef816113ff565b96506020880135610fff816113ff565b9550604088013561100f816113ff565b9450606088013561101f816113ff565b9350608088013567ffffffffffffffff8082111561103b578485fd5b6110478b838c01610ec0565b945060a08a013591508082111561105c578384fd5b506110698a828b01610ec0565b92505060c0880135801515811461107e578182fd5b8091505092959891949750929550565b6000806000606084860312156110a2578283fd5b83356110ad816113ff565b925060208401356110bd816113ff565b929592945050506040919091013590565b600080604083850312156110e0578182fd5b82356110eb816113ff565b946020939093013593505050565b60006020828403121561110a578081fd5b5035919050565b6000815180845260208085019450808401835b838110156111495781516001600160a01b031687529582019590820190600101611124565b509495945050505050565b6000815180845260208085019450808401835b8381101561114957815187529582019590820190600101611167565b6001600160a01b0391909116815260200190565b6001600160a01b03948516815292841660208401529083166040830152909116606082015260800190565b600060208252610f6f6020830184611111565b6000604082526111e86040830185611111565b82810360208401526111fa8185611111565b95945050505050565b6000608082526112166080830187611111565b82810360208401526112288187611154565b838103604085015261123a8187611154565b92505050821515606083015295945050505050565b60208082526014908201527310d417d19050d513d496480e881253959053125160621b604082015260600190565b6020808252600d908201526c494e56414c49445f434c41494d60981b604082015260600190565b60208082526024908201527f43505f464143544f5259203a20465245455a455f4455524154494f4e5f494e566040820152631053125160e21b606082015260800190565b6020808252601f908201527f43505f464143544f5259203a20434c4946465f524154455f494e56414c494400604082015260600190565b60208082526028908201527f43505f464143544f5259203a2050484153455f43414c4d5f4455524154494f4e60408201526717d253959053125160c21b606082015260800190565b60208082526022908201527f43505f464143544f5259203a20564553545f4455524154494f4e5f494e56414c604082015261125160f21b606082015260800190565b60208082526010908201526f1113d113d7d25392551250531256915160821b604082015260600190565b6020808252600990820152682727aa2fa7aba722a960b91b604082015260600190565b90815260200190565b6001600160a01b038116811461141457600080fd5b5056fea26469706673582212202c3b06bbf171ccc50b4d0ecf179ce40363dd10e7a2c08282d5d8b96eac5cca4f64736f6c634300060900330000000000000000000000005e5a7b76462e4bdf83aa98795644281bdba80b88000000000000000000000000327344b382ee1b44fb0a72945fcdcc7243200dd700000000000000000000000072d220ce168c4f361dd4dee5d826a01ad8598f6c00000000000000000000000095c4f5b83aa70810d4f142d58e5f7242bd891cb00000000000000000000000005e84190a270333ace5b9202a3f4cebf11b81bb010000000000000000000000006b208e08dcf6bd51f50c5da09d15b2d8e5c46cf2
Deployed ByteCode
0x608060405234801561001057600080fd5b50600436106101a95760003560e01c80636ca2aa95116100f9578063bdeb0a9111610097578063e0f5d89e11610071578063e0f5d89e1461031f578063eb774d0514610327578063ecfc2db01461032f578063f2fde38b14610342576101a9565b8063bdeb0a91146102fc578063c2c2757b1461030f578063ce90ea7414610317576101a9565b806389edcf14116100d357806389edcf14146102c6578063a58888db146102ce578063a6569b3f146102e1578063a820636b146102e9576101a9565b80636ca2aa95146102a357806381ab4d0a146102b65780638456db15146102be576101a9565b80634c59de661161016657806364ddb0131161014057806364ddb013146102605780636556c7e51461027357806369e4e417146102935780636c5ccb9b1461029b576101a9565b80634c59de66146102325780634e71e0c8146102455780635568587a1461024d576101a9565b806307b8a636146101ae5780630d009297146101c357806316048bc4146101d6578063294dafc0146101f45780633ff9b61e1461020957806341a1759c14610211575b600080fd5b6101c16101bc3660046110f9565b610355565b005b6101c16101d1366004610f53565b61038d565b6101de6103ed565b6040516101eb9190611183565b60405180910390f35b6101fc6103fc565b6040516101eb91906113f6565b6101fc610402565b61022461021f366004610f92565b610408565b6040516101eb9291906111d5565b6101c16102403660046110f9565b610500565b6101c1610557565b6101c161025b3660046110f9565b6105e5565b6101c161026e366004610f53565b610614565b610286610281366004610f92565b610660565b6040516101eb91906111c2565b6101de6106e3565b6101de610707565b6101c16102b13660046110f9565b61072b565b6101de61075a565b6101de61077e565b6101de61078d565b6101de6102dc3660046110ce565b610837565b6101de61086c565b6102866102f7366004610f53565b61087b565b6101de61030a36600461108e565b6108f1565b6101fc610933565b6101fc610939565b6101de61093f565b6101de610963565b6101c161033d366004610fca565b610987565b6101c1610350366004610f53565b610e3b565b6000546001600160a01b031633146103885760405162461bcd60e51b815260040161037f906113d3565b60405180910390fd5b600455565b600154600160a01b900460ff16156103b75760405162461bcd60e51b815260040161037f906113a9565b6001805460ff60a01b1916600160a01b179055600080546001600160a01b039092166001600160a01b0319909216919091179055565b6000546001600160a01b031681565b60065481565b60055481565b6001600160a01b038083166000818152600760208181526040808420958716845294815284832091815284832093835292835290839020815484518185028101850190955280855260609485949091849183018282801561049257602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311610474575b50505050509150808054806020026020016040519081016040528092919081815260200182805480156104ee57602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116104d0575b50505050509050915091509250929050565b6000546001600160a01b0316331461052a5760405162461bcd60e51b815260040161037f906113d3565b670de0b6b3a76400008111156105525760405162461bcd60e51b815260040161037f9061124f565b600655565b6001546001600160a01b031633146105815760405162461bcd60e51b815260040161037f9061127d565b600154600080546040516001600160a01b0393841693909116917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a360018054600080546001600160a01b03199081166001600160a01b03841617909155169055565b6000546001600160a01b0316331461060f5760405162461bcd60e51b815260040161037f906113d3565b600555565b6000546001600160a01b0316331461063e5760405162461bcd60e51b815260040161037f906113d3565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0380831660009081526007602090815260408083209385168352928152908290208054835181840281018401909452808452606093928301828280156106d657602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116106b8575b5050505050905092915050565b7f00000000000000000000000072d220ce168c4f361dd4dee5d826a01ad8598f6c81565b7f0000000000000000000000005e84190a270333ace5b9202a3f4cebf11b81bb0181565b6000546001600160a01b031633146107555760405162461bcd60e51b815260040161037f906113d3565b600355565b7f00000000000000000000000095c4f5b83aa70810d4f142d58e5f7242bd891cb081565b6001546001600160a01b031681565b6002546040516340925bc760e11b81526000916001600160a01b037f0000000000000000000000005e5a7b76462e4bdf83aa98795644281bdba80b88811692638124b78e926107e0921690600401611183565b602060405180830381600087803b1580156107fa57600080fd5b505af115801561080e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108329190610f76565b905090565b6008602052816000526040600020818154811061085057fe5b6000918252602090912001546001600160a01b03169150829050565b6002546001600160a01b031681565b6001600160a01b0381166000908152600860209081526040918290208054835181840281018401909452808452606093928301828280156108e557602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116108c7575b50505050509050919050565b6007602052826000526040600020602052816000526040600020818154811061091657fe5b6000918252602090912001546001600160a01b0316925083915050565b60045481565b60035481565b7f0000000000000000000000006b208e08dcf6bd51f50c5da09d15b2d8e5c46cf281565b7f0000000000000000000000005e5a7b76462e4bdf83aa98795644281bdba80b8881565b868584846004548260028151811061099b57fe5b602002602001015111156109c15760405162461bcd60e51b815260040161037f9061131f565b600554826004815181106109d157fe5b6020026020010151146109f65760405162461bcd60e51b815260040161037f90611367565b60065481600381518110610a0657fe5b602002602001015114610a2b5760405162461bcd60e51b815260040161037f906112e8565b60035482600381518110610a3b57fe5b60200260200101511015610a615760405162461bcd60e51b815260040161037f906112a4565b60408051600780825261010082019092526060916020820160e0803683370190505090508a81600081518110610a9357fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000095c4f5b83aa70810d4f142d58e5f7242bd891cb081600181518110610ae157fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508981600281518110610b0f57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508881600381518110610b3d57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000006b208e08dcf6bd51f50c5da09d15b2d8e5c46cf281600481518110610b8b57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000005e84190a270333ace5b9202a3f4cebf11b81bb0181600581518110610bd957fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000072d220ce168c4f361dd4dee5d826a01ad8598f6c81600681518110610c2757fe5b60200260200101906001600160a01b031690816001600160a01b03168152505086600081518110610c5457fe5b602002602001015160001415610c91576000196dffffffffffffffffffffffffffff1687600081518110610c8457fe5b6020026020010181815250505b6040516341dd3c3360e11b81526001600160a01b038d16906383ba786690610cc39084908c908c908c90600401611203565b600060405180830381600087803b158015610cdd57600080fd5b505af1158015610cf1573d6000803e3d6000fd5b5050505050600760008a6001600160a01b03166001600160a01b031681526020019081526020016000206000896001600160a01b03166001600160a01b031681526020019081526020016000208b9080600181540180825580915050600190039060005260206000200160009091909190916101000a8154816001600160a01b0302191690836001600160a01b03160217905550600860008b6001600160a01b03166001600160a01b031681526020019081526020016000208b9080600181540180825580915050600190039060005260206000200160009091909190916101000a8154816001600160a01b0302191690836001600160a01b031602179055507f0bd1e8ce555b4ec75d8b1c8113a8812659e0d94f0b4c67637dc049434604b45d89898c8e604051610e269493929190611197565b60405180910390a15050505050505050505050565b6000546001600160a01b03163314610e655760405162461bcd60e51b815260040161037f906113d3565b600080546040516001600160a01b03808516939216917fdcf55418cee3220104fef63f979ff3c4097ad240c0c43dcb33ce837748983e6291a3600180546001600160a01b0319166001600160a01b0392909216919091179055565b600082601f830112610ed0578081fd5b813567ffffffffffffffff80821115610ee7578283fd5b602080830260405182828201018181108582111715610f04578687fd5b604052848152945081850192508582018187018301881015610f2557600080fd5b600091505b84821015610f48578035845292820192600191909101908201610f2a565b505050505092915050565b600060208284031215610f64578081fd5b8135610f6f816113ff565b9392505050565b600060208284031215610f87578081fd5b8151610f6f816113ff565b60008060408385031215610fa4578081fd5b8235610faf816113ff565b91506020830135610fbf816113ff565b809150509250929050565b600080600080600080600060e0888a031215610fe4578283fd5b8735610fef816113ff565b96506020880135610fff816113ff565b9550604088013561100f816113ff565b9450606088013561101f816113ff565b9350608088013567ffffffffffffffff8082111561103b578485fd5b6110478b838c01610ec0565b945060a08a013591508082111561105c578384fd5b506110698a828b01610ec0565b92505060c0880135801515811461107e578182fd5b8091505092959891949750929550565b6000806000606084860312156110a2578283fd5b83356110ad816113ff565b925060208401356110bd816113ff565b929592945050506040919091013590565b600080604083850312156110e0578182fd5b82356110eb816113ff565b946020939093013593505050565b60006020828403121561110a578081fd5b5035919050565b6000815180845260208085019450808401835b838110156111495781516001600160a01b031687529582019590820190600101611124565b509495945050505050565b6000815180845260208085019450808401835b8381101561114957815187529582019590820190600101611167565b6001600160a01b0391909116815260200190565b6001600160a01b03948516815292841660208401529083166040830152909116606082015260800190565b600060208252610f6f6020830184611111565b6000604082526111e86040830185611111565b82810360208401526111fa8185611111565b95945050505050565b6000608082526112166080830187611111565b82810360208401526112288187611154565b838103604085015261123a8187611154565b92505050821515606083015295945050505050565b60208082526014908201527310d417d19050d513d496480e881253959053125160621b604082015260600190565b6020808252600d908201526c494e56414c49445f434c41494d60981b604082015260600190565b60208082526024908201527f43505f464143544f5259203a20465245455a455f4455524154494f4e5f494e566040820152631053125160e21b606082015260800190565b6020808252601f908201527f43505f464143544f5259203a20434c4946465f524154455f494e56414c494400604082015260600190565b60208082526028908201527f43505f464143544f5259203a2050484153455f43414c4d5f4455524154494f4e60408201526717d253959053125160c21b606082015260800190565b60208082526022908201527f43505f464143544f5259203a20564553545f4455524154494f4e5f494e56414c604082015261125160f21b606082015260800190565b60208082526010908201526f1113d113d7d25392551250531256915160821b604082015260600190565b6020808252600990820152682727aa2fa7aba722a960b91b604082015260600190565b90815260200190565b6001600160a01b038116811461141457600080fd5b5056fea26469706673582212202c3b06bbf171ccc50b4d0ecf179ce40363dd10e7a2c08282d5d8b96eac5cca4f64736f6c63430006090033