Overview
S Balance
0 S
S Value
$0.00More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 125 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Set Prices With ... | 6281242 | 27 hrs ago | IN | 0 S | 0.03453521 | ||||
Set Prices With ... | 6280534 | 27 hrs ago | IN | 0 S | 0.03108303 | ||||
Set Prices With ... | 6241008 | 34 hrs ago | IN | 0 S | 0.03121442 | ||||
Set Prices With ... | 6240538 | 34 hrs ago | IN | 0 S | 0.02998952 | ||||
Set Prices With ... | 6237713 | 35 hrs ago | IN | 0 S | 0.04458487 | ||||
Set Prices With ... | 6204567 | 42 hrs ago | IN | 0 S | 0.03349038 | ||||
Set Prices With ... | 6204494 | 42 hrs ago | IN | 0 S | 0.03371478 | ||||
Set Prices With ... | 6203897 | 43 hrs ago | IN | 0 S | 0.05212663 | ||||
Set Prices With ... | 6133829 | 2 days ago | IN | 0 S | 0.0445902 | ||||
Set Prices With ... | 6132467 | 2 days ago | IN | 0 S | 0.03345787 | ||||
Set Prices With ... | 6132167 | 2 days ago | IN | 0 S | 0.0441425 | ||||
Set Prices With ... | 6132097 | 2 days ago | IN | 0 S | 0.0283146 | ||||
Set Prices With ... | 6132086 | 2 days ago | IN | 0 S | 0.03465885 | ||||
Set Prices With ... | 6131999 | 2 days ago | IN | 0 S | 0.04416714 | ||||
Set Prices With ... | 6131934 | 2 days ago | IN | 0 S | 0.03465885 | ||||
Set Prices With ... | 6131925 | 2 days ago | IN | 0 S | 0.04267241 | ||||
Set Prices With ... | 6131793 | 2 days ago | IN | 0 S | 0.05353854 | ||||
Set Prices With ... | 6131686 | 2 days ago | IN | 0 S | 0.02805379 | ||||
Set Prices With ... | 6131017 | 2 days ago | IN | 0 S | 0.03279705 | ||||
Set Prices With ... | 5856850 | 4 days ago | IN | 0 S | 0.03454764 | ||||
Set Prices With ... | 5856682 | 4 days ago | IN | 0 S | 0.0512501 | ||||
Set Prices With ... | 5855049 | 4 days ago | IN | 0 S | 0.03399203 | ||||
Set Prices With ... | 5768821 | 5 days ago | IN | 0 S | 0.04377433 | ||||
Set Prices With ... | 5767631 | 5 days ago | IN | 0 S | 0.03368662 | ||||
Set Prices With ... | 5767370 | 5 days ago | IN | 0 S | 0.04360669 |
Loading...
Loading
Contract Name:
FastPriceFeed
Compiler Version
v0.6.12+commit.27d51765
Optimization Enabled:
Yes with 10 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT import "../libraries/math/SafeMath.sol"; import "./interfaces/ISecondaryPriceFeed.sol"; import "./interfaces/IFastPriceFeed.sol"; import "./interfaces/IFastPriceEvents.sol"; import "../core/interfaces/IVaultPriceFeed.sol"; import "../core/interfaces/IPositionRouter.sol"; import "../access/Governable.sol"; pragma solidity 0.6.12; contract FastPriceFeed is ISecondaryPriceFeed, IFastPriceFeed, Governable { using SafeMath for uint256; // fit data in a uint256 slot to save gas costs struct PriceDataItem { uint160 refPrice; // Chainlink price uint32 refTime; // last updated at time uint32 cumulativeRefDelta; // cumulative Chainlink price delta uint32 cumulativeFastDelta; // cumulative fast price delta } uint256 public constant PRICE_PRECISION = 10 ** 30; uint256 public constant CUMULATIVE_DELTA_PRECISION = 10 * 1000 * 1000; uint256 public constant MAX_REF_PRICE = type(uint160).max; uint256 public constant MAX_CUMULATIVE_REF_DELTA = type(uint32).max; uint256 public constant MAX_CUMULATIVE_FAST_DELTA = type(uint32).max; // uint256(~0) is 256 bits of 1s // shift the 1s by (256 - 32) to get (256 - 32) 0s followed by 32 1s uint256 constant public BITMASK_32 = uint256(~0) >> (256 - 32); uint256 public constant BASIS_POINTS_DIVISOR = 10000; uint256 public constant MAX_PRICE_DURATION = 30 minutes; bool public isInitialized; bool public isSpreadEnabled = false; address public vaultPriceFeed; address public fastPriceEvents; address public tokenManager; uint256 public override lastUpdatedAt; uint256 public override lastUpdatedBlock; uint256 public priceDuration; uint256 public maxPriceUpdateDelay; uint256 public spreadBasisPointsIfInactive; uint256 public spreadBasisPointsIfChainError; uint256 public minBlockInterval; uint256 public maxTimeDeviation; uint256 public priceDataInterval; // allowed deviation from primary price uint256 public maxDeviationBasisPoints; uint256 public minAuthorizations; uint256 public disableFastPriceVoteCount = 0; mapping (address => bool) public isUpdater; mapping (address => uint256) public prices; mapping (address => PriceDataItem) public priceData; mapping (address => uint256) public maxCumulativeDeltaDiffs; mapping (address => bool) public isSigner; mapping (address => bool) public disableFastPriceVotes; // array of tokens used in setCompactedPrices, saves L1 calldata gas costs address[] public tokens; // array of tokenPrecisions used in setCompactedPrices, saves L1 calldata gas costs // if the token price will be sent with 3 decimals, then tokenPrecision for that token // should be 10 ** 3 uint256[] public tokenPrecisions; event DisableFastPrice(address signer); event EnableFastPrice(address signer); event PriceData(address token, uint256 refPrice, uint256 fastPrice, uint256 cumulativeRefDelta, uint256 cumulativeFastDelta); event MaxCumulativeDeltaDiffExceeded(address token, uint256 refPrice, uint256 fastPrice, uint256 cumulativeRefDelta, uint256 cumulativeFastDelta); modifier onlySigner() { require(isSigner[msg.sender], "FastPriceFeed: forbidden"); _; } modifier onlyUpdater() { require(isUpdater[msg.sender], "FastPriceFeed: forbidden"); _; } modifier onlyTokenManager() { require(msg.sender == tokenManager, "FastPriceFeed: forbidden"); _; } constructor( uint256 _priceDuration, uint256 _maxPriceUpdateDelay, uint256 _minBlockInterval, uint256 _maxDeviationBasisPoints, address _fastPriceEvents, address _tokenManager ) public { require(_priceDuration <= MAX_PRICE_DURATION, "FastPriceFeed: invalid _priceDuration"); priceDuration = _priceDuration; maxPriceUpdateDelay = _maxPriceUpdateDelay; minBlockInterval = _minBlockInterval; maxDeviationBasisPoints = _maxDeviationBasisPoints; fastPriceEvents = _fastPriceEvents; tokenManager = _tokenManager; } function initialize(uint256 _minAuthorizations, address[] memory _signers, address[] memory _updaters) public onlyGov { require(!isInitialized, "FastPriceFeed: already initialized"); isInitialized = true; minAuthorizations = _minAuthorizations; for (uint256 i = 0; i < _signers.length; i++) { address signer = _signers[i]; isSigner[signer] = true; } for (uint256 i = 0; i < _updaters.length; i++) { address updater = _updaters[i]; isUpdater[updater] = true; } } function setSigner(address _account, bool _isActive) external override onlyGov { isSigner[_account] = _isActive; } function setUpdater(address _account, bool _isActive) external override onlyGov { isUpdater[_account] = _isActive; } function setFastPriceEvents(address _fastPriceEvents) external onlyGov { fastPriceEvents = _fastPriceEvents; } function setVaultPriceFeed(address _vaultPriceFeed) external override onlyGov { vaultPriceFeed = _vaultPriceFeed; } function setMaxTimeDeviation(uint256 _maxTimeDeviation) external onlyGov { maxTimeDeviation = _maxTimeDeviation; } function setPriceDuration(uint256 _priceDuration) external override onlyGov { require(_priceDuration <= MAX_PRICE_DURATION, "FastPriceFeed: invalid _priceDuration"); priceDuration = _priceDuration; } function setMaxPriceUpdateDelay(uint256 _maxPriceUpdateDelay) external override onlyGov { maxPriceUpdateDelay = _maxPriceUpdateDelay; } function setSpreadBasisPointsIfInactive(uint256 _spreadBasisPointsIfInactive) external override onlyGov { spreadBasisPointsIfInactive = _spreadBasisPointsIfInactive; } function setSpreadBasisPointsIfChainError(uint256 _spreadBasisPointsIfChainError) external override onlyGov { spreadBasisPointsIfChainError = _spreadBasisPointsIfChainError; } function setMinBlockInterval(uint256 _minBlockInterval) external override onlyGov { minBlockInterval = _minBlockInterval; } function setIsSpreadEnabled(bool _isSpreadEnabled) external override onlyGov { isSpreadEnabled = _isSpreadEnabled; } function setLastUpdatedAt(uint256 _lastUpdatedAt) external onlyGov { lastUpdatedAt = _lastUpdatedAt; } function setTokenManager(address _tokenManager) external onlyTokenManager { tokenManager = _tokenManager; } function setMaxDeviationBasisPoints(uint256 _maxDeviationBasisPoints) external override onlyTokenManager { maxDeviationBasisPoints = _maxDeviationBasisPoints; } function setMaxCumulativeDeltaDiffs(address[] memory _tokens, uint256[] memory _maxCumulativeDeltaDiffs) external override onlyTokenManager { for (uint256 i = 0; i < _tokens.length; i++) { address token = _tokens[i]; maxCumulativeDeltaDiffs[token] = _maxCumulativeDeltaDiffs[i]; } } function setPriceDataInterval(uint256 _priceDataInterval) external override onlyTokenManager { priceDataInterval = _priceDataInterval; } function setMinAuthorizations(uint256 _minAuthorizations) external onlyTokenManager { minAuthorizations = _minAuthorizations; } function setTokens(address[] memory _tokens, uint256[] memory _tokenPrecisions) external onlyGov { require(_tokens.length == _tokenPrecisions.length, "FastPriceFeed: invalid lengths"); tokens = _tokens; tokenPrecisions = _tokenPrecisions; } function setPrices(address[] memory _tokens, uint256[] memory _prices, uint256 _timestamp) external onlyUpdater { bool shouldUpdate = _setLastUpdatedValues(_timestamp); if (shouldUpdate) { address _fastPriceEvents = fastPriceEvents; address _vaultPriceFeed = vaultPriceFeed; for (uint256 i = 0; i < _tokens.length; i++) { address token = _tokens[i]; _setPrice(token, _prices[i], _vaultPriceFeed, _fastPriceEvents); } } } function setCompactedPrices(uint256[] memory _priceBitArray, uint256 _timestamp) external onlyUpdater { bool shouldUpdate = _setLastUpdatedValues(_timestamp); if (shouldUpdate) { address _fastPriceEvents = fastPriceEvents; address _vaultPriceFeed = vaultPriceFeed; for (uint256 i = 0; i < _priceBitArray.length; i++) { uint256 priceBits = _priceBitArray[i]; for (uint256 j = 0; j < 8; j++) { uint256 index = i * 8 + j; if (index >= tokens.length) { return; } uint256 startBit = 32 * j; uint256 price = (priceBits >> startBit) & BITMASK_32; address token = tokens[i * 8 + j]; uint256 tokenPrecision = tokenPrecisions[i * 8 + j]; uint256 adjustedPrice = price.mul(PRICE_PRECISION).div(tokenPrecision); _setPrice(token, adjustedPrice, _vaultPriceFeed, _fastPriceEvents); } } } } function setPricesWithBits(uint256 _priceBits, uint256 _timestamp) external override onlyUpdater { _setPricesWithBits(_priceBits, _timestamp); } function setPricesWithBitsAndExecute( address _positionRouter, uint256 _priceBits, uint256 _timestamp, uint256 _endIndexForIncreasePositions, uint256 _endIndexForDecreasePositions, uint256 _maxIncreasePositions, uint256 _maxDecreasePositions ) external onlyUpdater { _setPricesWithBits(_priceBits, _timestamp); IPositionRouter positionRouter = IPositionRouter(_positionRouter); uint256 maxEndIndexForIncrease = positionRouter.increasePositionRequestKeysStart().add(_maxIncreasePositions); uint256 maxEndIndexForDecrease = positionRouter.decreasePositionRequestKeysStart().add(_maxDecreasePositions); if (_endIndexForIncreasePositions > maxEndIndexForIncrease) { _endIndexForIncreasePositions = maxEndIndexForIncrease; } if (_endIndexForDecreasePositions > maxEndIndexForDecrease) { _endIndexForDecreasePositions = maxEndIndexForDecrease; } positionRouter.executeIncreasePositions(_endIndexForIncreasePositions, payable(msg.sender)); positionRouter.executeDecreasePositions(_endIndexForDecreasePositions, payable(msg.sender)); } function disableFastPrice() external onlySigner { require(!disableFastPriceVotes[msg.sender], "FastPriceFeed: already voted"); disableFastPriceVotes[msg.sender] = true; disableFastPriceVoteCount = disableFastPriceVoteCount.add(1); emit DisableFastPrice(msg.sender); } function enableFastPrice() external onlySigner { require(disableFastPriceVotes[msg.sender], "FastPriceFeed: already enabled"); disableFastPriceVotes[msg.sender] = false; disableFastPriceVoteCount = disableFastPriceVoteCount.sub(1); emit EnableFastPrice(msg.sender); } // under regular operation, the fastPrice (prices[token]) is returned and there is no spread returned from this function, // though VaultPriceFeed might apply its own spread // // if the fastPrice has not been updated within priceDuration then it is ignored and only _refPrice with a spread is used (spread: spreadBasisPointsIfInactive) // in case the fastPrice has not been updated for maxPriceUpdateDelay then the _refPrice with a larger spread is used (spread: spreadBasisPointsIfChainError) // // there will be a spread from the _refPrice to the fastPrice in the following cases: // - in case isSpreadEnabled is set to true // - in case the maxDeviationBasisPoints between _refPrice and fastPrice is exceeded // - in case watchers flag an issue // - in case the cumulativeFastDelta exceeds the cumulativeRefDelta by the maxCumulativeDeltaDiff function getPrice(address _token, uint256 _refPrice, bool _maximise) external override view returns (uint256) { if (block.timestamp > lastUpdatedAt.add(maxPriceUpdateDelay)) { if (_maximise) { return _refPrice.mul(BASIS_POINTS_DIVISOR.add(spreadBasisPointsIfChainError)).div(BASIS_POINTS_DIVISOR); } return _refPrice.mul(BASIS_POINTS_DIVISOR.sub(spreadBasisPointsIfChainError)).div(BASIS_POINTS_DIVISOR); } if (block.timestamp > lastUpdatedAt.add(priceDuration)) { if (_maximise) { return _refPrice.mul(BASIS_POINTS_DIVISOR.add(spreadBasisPointsIfInactive)).div(BASIS_POINTS_DIVISOR); } return _refPrice.mul(BASIS_POINTS_DIVISOR.sub(spreadBasisPointsIfInactive)).div(BASIS_POINTS_DIVISOR); } uint256 fastPrice = prices[_token]; if (fastPrice == 0) { return _refPrice; } uint256 diffBasisPoints = _refPrice > fastPrice ? _refPrice.sub(fastPrice) : fastPrice.sub(_refPrice); diffBasisPoints = diffBasisPoints.mul(BASIS_POINTS_DIVISOR).div(_refPrice); // create a spread between the _refPrice and the fastPrice if the maxDeviationBasisPoints is exceeded // or if watchers have flagged an issue with the fast price bool hasSpread = !favorFastPrice(_token) || diffBasisPoints > maxDeviationBasisPoints; if (hasSpread) { // return the higher of the two prices if (_maximise) { return _refPrice > fastPrice ? _refPrice : fastPrice; } // return the lower of the two prices return _refPrice < fastPrice ? _refPrice : fastPrice; } return fastPrice; } function favorFastPrice(address _token) public view returns (bool) { if (isSpreadEnabled) { return false; } if (disableFastPriceVoteCount >= minAuthorizations) { // force a spread if watchers have flagged an issue with the fast price return false; } (/* uint256 prevRefPrice */, /* uint256 refTime */, uint256 cumulativeRefDelta, uint256 cumulativeFastDelta) = getPriceData(_token); if (cumulativeFastDelta > cumulativeRefDelta && cumulativeFastDelta.sub(cumulativeRefDelta) > maxCumulativeDeltaDiffs[_token]) { // force a spread if the cumulative delta for the fast price feed exceeds the cumulative delta // for the Chainlink price feed by the maxCumulativeDeltaDiff allowed return false; } return true; } function getPriceData(address _token) public view returns (uint256, uint256, uint256, uint256) { PriceDataItem memory data = priceData[_token]; return (uint256(data.refPrice), uint256(data.refTime), uint256(data.cumulativeRefDelta), uint256(data.cumulativeFastDelta)); } function _setPricesWithBits(uint256 _priceBits, uint256 _timestamp) private { bool shouldUpdate = _setLastUpdatedValues(_timestamp); if (shouldUpdate) { address _fastPriceEvents = fastPriceEvents; address _vaultPriceFeed = vaultPriceFeed; for (uint256 j = 0; j < 8; j++) { uint256 index = j; if (index >= tokens.length) { return; } uint256 startBit = 32 * j; uint256 price = (_priceBits >> startBit) & BITMASK_32; address token = tokens[j]; uint256 tokenPrecision = tokenPrecisions[j]; uint256 adjustedPrice = price.mul(PRICE_PRECISION).div(tokenPrecision); _setPrice(token, adjustedPrice, _vaultPriceFeed, _fastPriceEvents); } } } function _setPrice(address _token, uint256 _price, address _vaultPriceFeed, address _fastPriceEvents) private { if (_vaultPriceFeed != address(0)) { uint256 refPrice = IVaultPriceFeed(_vaultPriceFeed).getLatestPrimaryPrice(_token); uint256 fastPrice = prices[_token]; (uint256 prevRefPrice, uint256 refTime, uint256 cumulativeRefDelta, uint256 cumulativeFastDelta) = getPriceData(_token); if (prevRefPrice > 0) { uint256 refDeltaAmount = refPrice > prevRefPrice ? refPrice.sub(prevRefPrice) : prevRefPrice.sub(refPrice); uint256 fastDeltaAmount = fastPrice > _price ? fastPrice.sub(_price) : _price.sub(fastPrice); // reset cumulative delta values if it is a new time window if (refTime.div(priceDataInterval) != block.timestamp.div(priceDataInterval)) { cumulativeRefDelta = 0; cumulativeFastDelta = 0; } cumulativeRefDelta = cumulativeRefDelta.add(refDeltaAmount.mul(CUMULATIVE_DELTA_PRECISION).div(prevRefPrice)); cumulativeFastDelta = cumulativeFastDelta.add(fastDeltaAmount.mul(CUMULATIVE_DELTA_PRECISION).div(fastPrice)); } if (cumulativeFastDelta > cumulativeRefDelta && cumulativeFastDelta.sub(cumulativeRefDelta) > maxCumulativeDeltaDiffs[_token]) { emit MaxCumulativeDeltaDiffExceeded(_token, refPrice, fastPrice, cumulativeRefDelta, cumulativeFastDelta); } _setPriceData(_token, refPrice, cumulativeRefDelta, cumulativeFastDelta); emit PriceData(_token, refPrice, fastPrice, cumulativeRefDelta, cumulativeFastDelta); } prices[_token] = _price; _emitPriceEvent(_fastPriceEvents, _token, _price); } function _setPriceData(address _token, uint256 _refPrice, uint256 _cumulativeRefDelta, uint256 _cumulativeFastDelta) private { require(_refPrice < MAX_REF_PRICE, "FastPriceFeed: invalid refPrice"); // skip validation of block.timestamp, it should only be out of range after the year 2100 require(_cumulativeRefDelta < MAX_CUMULATIVE_REF_DELTA, "FastPriceFeed: invalid cumulativeRefDelta"); require(_cumulativeFastDelta < MAX_CUMULATIVE_FAST_DELTA, "FastPriceFeed: invalid cumulativeFastDelta"); priceData[_token] = PriceDataItem( uint160(_refPrice), uint32(block.timestamp), uint32(_cumulativeRefDelta), uint32(_cumulativeFastDelta) ); } function _emitPriceEvent(address _fastPriceEvents, address _token, uint256 _price) private { if (_fastPriceEvents == address(0)) { return; } IFastPriceEvents(_fastPriceEvents).emitPriceEvent(_token, _price); } function _setLastUpdatedValues(uint256 _timestamp) private returns (bool) { if (minBlockInterval > 0) { require(block.number.sub(lastUpdatedBlock) >= minBlockInterval, "FastPriceFeed: minBlockInterval not yet passed"); } uint256 _maxTimeDeviation = maxTimeDeviation; require(_timestamp > block.timestamp.sub(_maxTimeDeviation), "FastPriceFeed: _timestamp below allowed range"); require(_timestamp < block.timestamp.add(_maxTimeDeviation), "FastPriceFeed: _timestamp exceeds allowed range"); // do not update prices if _timestamp is before the current lastUpdatedAt value if (_timestamp < lastUpdatedAt) { return false; } lastUpdatedAt = _timestamp; lastUpdatedBlock = block.number; return true; } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; contract Governable { address public gov; constructor() public { gov = msg.sender; } modifier onlyGov() { require(msg.sender == gov, "Governable: forbidden"); _; } function setGov(address _gov) external onlyGov { gov = _gov; } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IPositionRouter { function increasePositionRequestKeysStart() external returns (uint256); function decreasePositionRequestKeysStart() external returns (uint256); function executeIncreasePositions(uint256 _count, address payable _executionFeeReceiver) external; function executeDecreasePositions(uint256 _count, address payable _executionFeeReceiver) external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IVaultPriceFeed { function adjustmentBasisPoints(address _token) external view returns (uint256); function isAdjustmentAdditive(address _token) external view returns (bool); function setAdjustment(address _token, bool _isAdditive, uint256 _adjustmentBps) external; function setUseV2Pricing(bool _useV2Pricing) external; function setIsAmmEnabled(bool _isEnabled) external; function setIsSecondaryPriceEnabled(bool _isEnabled) external; function setSpreadBasisPoints(address _token, uint256 _spreadBasisPoints) external; function setSpreadThresholdBasisPoints(uint256 _spreadThresholdBasisPoints) external; function setFavorPrimaryPrice(bool _favorPrimaryPrice) external; function setPriceSampleSpace(uint256 _priceSampleSpace) external; function setMaxStrictPriceDeviation(uint256 _maxStrictPriceDeviation) external; function getPrice(address _token, bool _maximise, bool _includeAmmPrice, bool _useSwapPricing) external view returns (uint256); function getAmmPrice(address _token) external view returns (uint256); function getLatestPrimaryPrice(address _token) external view returns (uint256); function getPrimaryPrice(address _token, bool _maximise) external view returns (uint256); function setTokenConfig( address _token, address _priceFeed, uint256 _priceDecimals, bool _isStrictStable ) external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IFastPriceEvents { function emitPriceEvent(address _token, uint256 _price) external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IFastPriceFeed { function lastUpdatedAt() external view returns (uint256); function lastUpdatedBlock() external view returns (uint256); function setSigner(address _account, bool _isActive) external; function setUpdater(address _account, bool _isActive) external; function setPriceDuration(uint256 _priceDuration) external; function setMaxPriceUpdateDelay(uint256 _maxPriceUpdateDelay) external; function setSpreadBasisPointsIfInactive(uint256 _spreadBasisPointsIfInactive) external; function setSpreadBasisPointsIfChainError(uint256 _spreadBasisPointsIfChainError) external; function setMinBlockInterval(uint256 _minBlockInterval) external; function setIsSpreadEnabled(bool _isSpreadEnabled) external; function setMaxDeviationBasisPoints(uint256 _maxDeviationBasisPoints) external; function setMaxCumulativeDeltaDiffs(address[] memory _tokens, uint256[] memory _maxCumulativeDeltaDiffs) external; function setPriceDataInterval(uint256 _priceDataInterval) external; function setVaultPriceFeed(address _vaultPriceFeed) external; function setPricesWithBits(uint256 _priceBits, uint256 _timestamp) external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface ISecondaryPriceFeed { function getPrice(address _token, uint256 _referencePrice, bool _maximise) external view returns (uint256); }
{ "optimizer": { "enabled": true, "runs": 10 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"uint256","name":"_priceDuration","type":"uint256"},{"internalType":"uint256","name":"_maxPriceUpdateDelay","type":"uint256"},{"internalType":"uint256","name":"_minBlockInterval","type":"uint256"},{"internalType":"uint256","name":"_maxDeviationBasisPoints","type":"uint256"},{"internalType":"address","name":"_fastPriceEvents","type":"address"},{"internalType":"address","name":"_tokenManager","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"signer","type":"address"}],"name":"DisableFastPrice","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"signer","type":"address"}],"name":"EnableFastPrice","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"refPrice","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"fastPrice","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"cumulativeRefDelta","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"cumulativeFastDelta","type":"uint256"}],"name":"MaxCumulativeDeltaDiffExceeded","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"refPrice","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"fastPrice","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"cumulativeRefDelta","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"cumulativeFastDelta","type":"uint256"}],"name":"PriceData","type":"event"},{"inputs":[],"name":"BASIS_POINTS_DIVISOR","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"BITMASK_32","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"CUMULATIVE_DELTA_PRECISION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_CUMULATIVE_FAST_DELTA","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_CUMULATIVE_REF_DELTA","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_PRICE_DURATION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_REF_PRICE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PRICE_PRECISION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"disableFastPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"disableFastPriceVoteCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"disableFastPriceVotes","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableFastPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"fastPriceEvents","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"}],"name":"favorFastPrice","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"uint256","name":"_refPrice","type":"uint256"},{"internalType":"bool","name":"_maximise","type":"bool"}],"name":"getPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"}],"name":"getPriceData","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"gov","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minAuthorizations","type":"uint256"},{"internalType":"address[]","name":"_signers","type":"address[]"},{"internalType":"address[]","name":"_updaters","type":"address[]"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"isInitialized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isSigner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isSpreadEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isUpdater","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastUpdatedAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastUpdatedBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"maxCumulativeDeltaDiffs","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxDeviationBasisPoints","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxPriceUpdateDelay","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTimeDeviation","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minAuthorizations","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minBlockInterval","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"priceData","outputs":[{"internalType":"uint160","name":"refPrice","type":"uint160"},{"internalType":"uint32","name":"refTime","type":"uint32"},{"internalType":"uint32","name":"cumulativeRefDelta","type":"uint32"},{"internalType":"uint32","name":"cumulativeFastDelta","type":"uint32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"priceDataInterval","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"priceDuration","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"prices","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_priceBitArray","type":"uint256[]"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"setCompactedPrices","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_fastPriceEvents","type":"address"}],"name":"setFastPriceEvents","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_gov","type":"address"}],"name":"setGov","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isSpreadEnabled","type":"bool"}],"name":"setIsSpreadEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_lastUpdatedAt","type":"uint256"}],"name":"setLastUpdatedAt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_tokens","type":"address[]"},{"internalType":"uint256[]","name":"_maxCumulativeDeltaDiffs","type":"uint256[]"}],"name":"setMaxCumulativeDeltaDiffs","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxDeviationBasisPoints","type":"uint256"}],"name":"setMaxDeviationBasisPoints","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxPriceUpdateDelay","type":"uint256"}],"name":"setMaxPriceUpdateDelay","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxTimeDeviation","type":"uint256"}],"name":"setMaxTimeDeviation","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minAuthorizations","type":"uint256"}],"name":"setMinAuthorizations","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minBlockInterval","type":"uint256"}],"name":"setMinBlockInterval","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_priceDataInterval","type":"uint256"}],"name":"setPriceDataInterval","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_priceDuration","type":"uint256"}],"name":"setPriceDuration","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_tokens","type":"address[]"},{"internalType":"uint256[]","name":"_prices","type":"uint256[]"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"setPrices","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_priceBits","type":"uint256"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"setPricesWithBits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_positionRouter","type":"address"},{"internalType":"uint256","name":"_priceBits","type":"uint256"},{"internalType":"uint256","name":"_timestamp","type":"uint256"},{"internalType":"uint256","name":"_endIndexForIncreasePositions","type":"uint256"},{"internalType":"uint256","name":"_endIndexForDecreasePositions","type":"uint256"},{"internalType":"uint256","name":"_maxIncreasePositions","type":"uint256"},{"internalType":"uint256","name":"_maxDecreasePositions","type":"uint256"}],"name":"setPricesWithBitsAndExecute","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"},{"internalType":"bool","name":"_isActive","type":"bool"}],"name":"setSigner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_spreadBasisPointsIfChainError","type":"uint256"}],"name":"setSpreadBasisPointsIfChainError","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_spreadBasisPointsIfInactive","type":"uint256"}],"name":"setSpreadBasisPointsIfInactive","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenManager","type":"address"}],"name":"setTokenManager","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_tokens","type":"address[]"},{"internalType":"uint256[]","name":"_tokenPrecisions","type":"uint256[]"}],"name":"setTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"},{"internalType":"bool","name":"_isActive","type":"bool"}],"name":"setUpdater","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_vaultPriceFeed","type":"address"}],"name":"setVaultPriceFeed","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"spreadBasisPointsIfChainError","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"spreadBasisPointsIfInactive","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokenManager","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tokenPrecisions","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tokens","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"vaultPriceFeed","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
60806040526000805460ff60a81b19168155600f5534801561002057600080fd5b5060405162002f0938038062002f09833981810160405260c081101561004557600080fd5b508051602082015160408301516060840151608085015160a090950151600080546001600160a01b0319163317905593949293919290916107088611156100be5760405162461bcd60e51b815260040180806020018281038252602581526020018062002ee46025913960400191505060405180910390fd5b600695909555600793909355600a91909155600d55600280546001600160a01b039283166001600160a01b03199182161790915560038054929093169116179055612dd5806200010f6000396000f3fe608060405234801561001057600080fd5b50600436106102e55760003560e01c806372279ba11161018f57806372279ba11461077c57806374bfed89146107c8578063776d16c1146107d0578063782661bc146107ed5780637cb2b79c146109125780637df73e27146109385780637fbc79c61461095e5780637fece36814610a88578063807c9782146103e357806382553aad14610abc5780638b7677f414610ad957806395082d2514610af6578063a2b47c1614610afe578063a374242514610b06578063a6eca89614610b2c578063b0a2566614610b34578063b3606b5614610b3c578063b70c7b7014610b44578063c8390a4814610b61578063c84a912414610c84578063cab44b7614610c8c578063ce98dfa814610cea578063cfad57a214610d09578063cfed246b14610d2f578063d6a153f114610d55578063d925351a14610d72578063de0d1b9414610d8f578063dfb481c914610dac578063e64559ad14610db4578063e68a22c014610dbc578063eeaa783a14610dc4578063f90ce5ba14610dcc576102e5565b806303b04936146102ea57806303cd25711461032457806303f4d7dc1461033e5780630604ddea146103e35780630e9272ea146103eb578063126082cf1461040f57806312d43a511461041757806314dd2dce1461041f578063162ac4e01461043c57806317835d1c146104625780631a15339114610485578063238aafb7146104b3578063287800c9146104d95780632a709b14146104e15780632e9cd94b146104e957806331cb61051461050657806332e5f9fa14610534578063392e53cd1461057e5780633aa08f861461058657806344c231931461058e5780634bd66c1c146103e35780634c0e31c8146105ab5780634d11fb4a146106ce5780634f64b2be146106eb5780634fdfb0861461070857806354aea1271461072e578063668d3d6514610736578063695d41841461073e5780636c56fd05146107465780636ccd47c41461076c578063715c753614610774575b600080fd5b6103106004803603602081101561030057600080fd5b50356001600160a01b0316610dd4565b604080519115158252519081900360200190f35b61032c610de9565b60408051918252519081900360200190f35b6103e16004803603604081101561035457600080fd5b810190602081018135600160201b81111561036e57600080fd5b82018360208201111561038057600080fd5b803590602001918460208302840111600160201b831117156103a157600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295505091359250610def915050565b005b61032c610f66565b6103f3610f6e565b604080516001600160a01b039092168252519081900360200190f35b61032c610f7d565b6103f3610f83565b6103e16004803603602081101561043557600080fd5b5035610f92565b6103e16004803603602081101561045257600080fd5b50356001600160a01b0316610fe4565b6103e16004803603604081101561047857600080fd5b5080359060200135611053565b6103e16004803603604081101561049b57600080fd5b506001600160a01b03813516906020013515156110af565b6103e1600480360360208110156104c957600080fd5b50356001600160a01b0316611127565b61032c611196565b6103f361119c565b6103e1600480360360208110156104ff57600080fd5b50356111ab565b6103e16004803603604081101561051c57600080fd5b506001600160a01b03813516906020013515156111fd565b6103e1600480360360e081101561054a57600080fd5b506001600160a01b038135169060208101359060408101359060608101359060808101359060a08101359060c00135611275565b61031061147d565b61032c61148d565b6103e1600480360360208110156105a457600080fd5b5035611493565b6103e1600480360360408110156105c157600080fd5b810190602081018135600160201b8111156105db57600080fd5b8201836020820111156105ed57600080fd5b803590602001918460208302840111600160201b8311171561060e57600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b81111561065d57600080fd5b82018360208201111561066f57600080fd5b803590602001918460208302840111600160201b8311171561069057600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611526945050505050565b61032c600480360360208110156106e457600080fd5b50356115d1565b6103f36004803603602081101561070157600080fd5b50356115ef565b6103106004803603602081101561071e57600080fd5b50356001600160a01b0316611616565b61032c61162b565b61032c611631565b610310611637565b6103106004803603602081101561075c57600080fd5b50356001600160a01b0316611647565b6103e16116d2565b61032c6117e5565b6107a26004803603602081101561079257600080fd5b50356001600160a01b03166117eb565b604080519485526020850193909352838301919091526060830152519081900360800190f35b61032c611869565b6103e1600480360360208110156107e657600080fd5b503561186f565b6103e16004803603606081101561080357600080fd5b810190602081018135600160201b81111561081d57600080fd5b82018360208201111561082f57600080fd5b803590602001918460208302840111600160201b8311171561085057600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b81111561089f57600080fd5b8201836020820111156108b157600080fd5b803590602001918460208302840111600160201b831117156108d257600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955050913592506118c1915050565b6103e16004803603602081101561092857600080fd5b50356001600160a01b031661198f565b6103106004803603602081101561094e57600080fd5b50356001600160a01b03166119fe565b6103e16004803603606081101561097457600080fd5b81359190810190604081016020820135600160201b81111561099557600080fd5b8201836020820111156109a757600080fd5b803590602001918460208302840111600160201b831117156109c857600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b811115610a1757600080fd5b820183602082011115610a2957600080fd5b803590602001918460208302840111600160201b83111715610a4a57600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611a13945050505050565b61032c60048036036060811015610a9e57600080fd5b506001600160a01b0381351690602081013590604001351515611b6c565b6103e160048036036020811015610ad257600080fd5b5035611cf2565b6103e160048036036020811015610aef57600080fd5b5035611d44565b61032c611d96565b61032c611da6565b61032c60048036036020811015610b1c57600080fd5b50356001600160a01b0316611dad565b61032c611dbf565b61032c611dc5565b61032c611dcb565b6103e160048036036020811015610b5a57600080fd5b5035611dd1565b6103e160048036036040811015610b7757600080fd5b810190602081018135600160201b811115610b9157600080fd5b820183602082011115610ba357600080fd5b803590602001918460208302840111600160201b83111715610bc457600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b811115610c1357600080fd5b820183602082011115610c2557600080fd5b803590602001918460208302840111600160201b83111715610c4657600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611e23945050505050565b6103e1611eed565b610cb260048036036020811015610ca257600080fd5b50356001600160a01b0316612004565b604080516001600160a01b03909516855263ffffffff9384166020860152918316848301529091166060830152519081900360800190f35b6103e160048036036020811015610d0057600080fd5b50351515612043565b6103e160048036036020811015610d1f57600080fd5b50356001600160a01b03166120ae565b61032c60048036036020811015610d4557600080fd5b50356001600160a01b031661211d565b6103e160048036036020811015610d6b57600080fd5b503561212f565b6103e160048036036020811015610d8857600080fd5b5035612181565b6103e160048036036020811015610da557600080fd5b50356121d3565b61032c612225565b61032c61222b565b61032c612231565b6103f361223c565b61032c61224b565b60156020526000908152604090205460ff1681565b60065481565b3360009081526010602052604090205460ff16610e41576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b6000610e4c82612251565b90508015610f60576002546001546001600160a01b03918216911660005b8551811015610f5c576000868281518110610e8157fe5b6020026020010151905060005b6008811015610f5257601654600884028201908110610eb35750505050505050610f62565b60168054602084029185831c63ffffffff169160009190600889028701908110610ed957fe5b6000918252602082200154601780546001600160a01b0390921693509060088a028801908110610f0557fe5b60009182526020822001549150610f3282610f2c8668327cb2734119d3b7a9601e1b61235d565b906123bf565b9050610f4083828c8e6123fe565b505060019094019350610e8e92505050565b5050600101610e6a565b5050505b505b5050565b63ffffffff81565b6002546001600160a01b031681565b61271081565b6000546001600160a01b031681565b6000546001600160a01b03163314610fdf576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600455565b6000546001600160a01b03163314611031576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600280546001600160a01b0319166001600160a01b0392909216919091179055565b3360009081526010602052604090205460ff166110a5576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b610f628282612693565b6000546001600160a01b031633146110fc576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152601060205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314611174576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600180546001600160a01b0319166001600160a01b0392909216919091179055565b600e5481565b6003546001600160a01b031681565b6003546001600160a01b031633146111f8576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600c55565b6000546001600160a01b0316331461124a576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152601460205260409020805460ff1916911515919091179055565b3360009081526010602052604090205460ff166112c7576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b6112d18686612693565b6000879050600061134984836001600160a01b0316639b5786206040518163ffffffff1660e01b8152600401602060405180830381600087803b15801561131757600080fd5b505af115801561132b573d6000803e3d6000fd5b505050506040513d602081101561134157600080fd5b505190612769565b9050600061138c84846001600160a01b0316631bca8cf06040518163ffffffff1660e01b8152600401602060405180830381600087803b15801561131757600080fd5b90508187111561139a578196505b808611156113a6578095505b60408051629a208160e81b81526004810189905233602482015290516001600160a01b03851691639a20810091604480830192600092919082900301818387803b1580156113f357600080fd5b505af1158015611407573d6000803e3d6000fd5b50506040805163f3883d8b60e01b8152600481018a905233602482015290516001600160a01b038716935063f3883d8b9250604480830192600092919082900301818387803b15801561145957600080fd5b505af115801561146d573d6000803e3d6000fd5b5050505050505050505050505050565b600054600160a01b900460ff1681565b600b5481565b6000546001600160a01b031633146114e0576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6107088111156115215760405162461bcd60e51b8152600401808060200182810382526025815260200180612c1b6025913960400191505060405180910390fd5b600655565b6003546001600160a01b03163314611573576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b60005b8251811015610f6057600083828151811061158d57fe5b602002602001015190508282815181106115a357fe5b6020908102919091018101516001600160a01b03909216600090815260139091526040902055600101611576565b601781815481106115de57fe5b600091825260209091200154905081565b601681815481106115fc57fe5b6000918252602090912001546001600160a01b0316905081565b60106020526000908152604090205460ff1681565b60045481565b61070881565b600054600160a81b900460ff1681565b60008054600160a81b900460ff1615611662575060006116cd565b600e54600f5410611675575060006116cd565b600080611681846117eb565b93509350505081811180156116b657506001600160a01b0384166000908152601360205260409020546116b482846127c1565b115b156116c6576000925050506116cd565b6001925050505b919050565b3360009081526014602052604090205460ff16611724576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b3360009081526015602052604090205460ff16611788576040805162461bcd60e51b815260206004820152601e60248201527f466173745072696365466565643a20616c726561647920656e61626c65640000604482015290519081900360640190fd5b336000908152601560205260409020805460ff19169055600f546117ad9060016127c1565b600f556040805133815290517f9fe0c305c33aa92757a537936872a60be0d91549a4303cc99fd8b7fce8a002759181900360200190a1565b600d5481565b6000806000806117f9612b13565b505050506001600160a01b039182166000908152601260209081526040918290208251608081018452905494851680825263ffffffff600160a01b87048116938301849052600160c01b87048116948301859052600160e01b909604909516606090910181905293949093919250565b60085481565b6000546001600160a01b031633146118bc576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600b55565b3360009081526010602052604090205460ff16611913576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600061191e82612251565b90508015611989576002546001546001600160a01b03918216911660005b865181101561198557600087828151811061195357fe5b6020026020010151905061197c8188848151811061196d57fe5b602002602001015185876123fe565b5060010161193c565b5050505b50505050565b6003546001600160a01b031633146119dc576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600380546001600160a01b0319166001600160a01b0392909216919091179055565b60146020526000908152604090205460ff1681565b6000546001600160a01b03163314611a60576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600054600160a01b900460ff1615611aa95760405162461bcd60e51b8152600401808060200182810382526022815260200180612d7e6022913960400191505060405180910390fd5b6000805460ff60a01b1916600160a01b178155600e8490555b8251811015611b15576000838281518110611ad957fe5b6020908102919091018101516001600160a01b03166000908152601490915260409020805460ff19166001908117909155919091019050611ac2565b5060005b8151811015611989576000828281518110611b3057fe5b6020908102919091018101516001600160a01b03166000908152601090915260409020805460ff19166001908117909155919091019050611b19565b6000611b8560075460045461276990919063ffffffff16565b421115611be0578115611bc057611bb9612710610f2c611bb260095461271061276990919063ffffffff16565b869061235d565b9050611ceb565b611bb9612710610f2c611bb26009546127106127c190919063ffffffff16565b600654600454611bef91612769565b421115611c3c578115611c1c57611bb9612710610f2c611bb260085461271061276990919063ffffffff16565b611bb9612710610f2c611bb26008546127106127c190919063ffffffff16565b6001600160a01b03841660009081526011602052604090205480611c635783915050611ceb565b6000818511611c7b57611c7682866127c1565b611c85565b611c8585836127c1565b9050611c9785610f2c8361271061235d565b90506000611ca487611647565b1580611cb15750600d5482115b90508015611ce5578415611cd857828611611ccc5782611cce565b855b9350505050611ceb565b828610611ccc5782611cce565b50909150505b9392505050565b6003546001600160a01b03163314611d3f576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600d55565b6000546001600160a01b03163314611d91576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600755565b68327cb2734119d3b7a9601e1b81565b6298968081565b60136020526000908152604090205481565b60095481565b600f5481565b600a5481565b6000546001600160a01b03163314611e1e576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600855565b6000546001600160a01b03163314611e70576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b8051825114611ec6576040805162461bcd60e51b815260206004820152601e60248201527f466173745072696365466565643a20696e76616c6964206c656e677468730000604482015290519081900360640190fd5b8151611ed9906016906020850190612b3a565b508051610f60906017906020840190612b9f565b3360009081526014602052604090205460ff16611f3f576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b3360009081526015602052604090205460ff1615611fa3576040805162461bcd60e51b815260206004820152601c60248201527b11985cdd141c9a58d9519959590e88185b1c9958591e481d9bdd195960221b604482015290519081900360640190fd5b336000908152601560205260409020805460ff19166001908117909155600f54611fcc91612769565b600f556040805133815290517f4c0c5fabf50e808e3bc8d19577d305e3a7163eea7e8a74a50caa8896694cd44b9181900360200190a1565b6012602052600090815260409020546001600160a01b0381169063ffffffff600160a01b8204811691600160c01b8104821691600160e01b9091041684565b6000546001600160a01b03163314612090576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b60008054911515600160a81b0260ff60a81b19909216919091179055565b6000546001600160a01b031633146120fb576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600080546001600160a01b0319166001600160a01b0392909216919091179055565b60116020526000908152604090205481565b6000546001600160a01b0316331461217c576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600a55565b6003546001600160a01b031633146121ce576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600e55565b6000546001600160a01b03163314612220576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600955565b600c5481565b60075481565b6001600160a01b0381565b6001546001600160a01b031681565b60055481565b600a54600090156122aa57600a5460055461226d9043906127c1565b10156122aa5760405162461bcd60e51b815260040180806020018281038252602e815260200180612d27602e913960400191505060405180910390fd5b600b546122b742826127c1565b83116122f45760405162461bcd60e51b815260040180806020018281038252602d815260200180612cfa602d913960400191505060405180910390fd5b6122fe4282612769565b831061233b5760405162461bcd60e51b815260040180806020018281038252602f815260200180612caa602f913960400191505060405180910390fd5b60045483101561234f5760009150506116cd565b505060045543600555600190565b60008261236c575060006123b9565b8282028284828161237957fe5b04146123b65760405162461bcd60e51b8152600401808060200182810382526021815260200180612cd96021913960400191505060405180910390fd5b90505b92915050565b60006123b683836040518060400160405280601a815260200179536166654d6174683a206469766973696f6e206279207a65726f60301b815250612803565b6001600160a01b0382161561266d576000826001600160a01b03166356bf9de4866040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561245c57600080fd5b505afa158015612470573d6000803e3d6000fd5b505050506040513d602081101561248657600080fd5b50516001600160a01b0386166000908152601160205260408120549192508080806124b08a6117eb565b935093509350935060008411156125775760008487116124d9576124d485886127c1565b6124e3565b6124e387866127c1565b905060008a87116124fd576124f88b886127c1565b612507565b612507878c6127c1565b905061251e600c54426123bf90919063ffffffff16565b600c5461252c9087906123bf565b1461253a5760009350600092505b61255561254e87610f2c856298968061235d565b8590612769565b935061257261256b88610f2c846298968061235d565b8490612769565b925050505b81811180156125a657506001600160a01b038a166000908152601360205260409020546125a482846127c1565b115b1561260357604080516001600160a01b038c16815260208101889052808201879052606081018490526080810183905290517fe582322b389ad06b2bbf619cd6da3f16a288ec873ea0fa6df4d72f3d9480b4479181900360a00190a15b61260f8a8784846128a5565b604080516001600160a01b038c16815260208101889052808201879052606081018490526080810183905290517f23b9387f81fca646aac1dc4487ede045c65f5f7445482906565f01e05afdb3a89181900360a00190a15050505050505b6001600160a01b0384166000908152601160205260409020839055611989818585612a3b565b600061269e82612251565b90508015610f60576002546001546001600160a01b03918216911660005b6008811015610f5c57601654819081106126da575050505050610f62565b60168054602084029189831c63ffffffff169160009190869081106126fb57fe5b6000918252602082200154601780546001600160a01b039092169350908790811061272257fe5b6000918252602082200154915061274982610f2c8668327cb2734119d3b7a9601e1b61235d565b905061275783828a8c6123fe565b5050600190940193506126bc92505050565b6000828201838110156123b6576040805162461bcd60e51b815260206004820152601b60248201527a536166654d6174683a206164646974696f6e206f766572666c6f7760281b604482015290519081900360640190fd5b60006123b683836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612ab9565b6000818361288f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561285457818101518382015260200161283c565b50505050905090810190601f1680156128815780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50600083858161289b57fe5b0495945050505050565b6001600160a01b038310612900576040805162461bcd60e51b815260206004820152601f60248201527f466173745072696365466565643a20696e76616c696420726566507269636500604482015290519081900360640190fd5b63ffffffff82106129425760405162461bcd60e51b8152600401808060200182810382526029815260200180612d556029913960400191505060405180910390fd5b63ffffffff81106129845760405162461bcd60e51b815260040180806020018281038252602a815260200180612c40602a913960400191505060405180910390fd5b604080516080810182526001600160a01b03948516815263ffffffff4281166020808401918252958216838501908152948216606084019081529787166000908152601290965292909420905181549251935196518516600160e01b026001600160e01b03978616600160c01b0263ffffffff60c01b1995909616600160a01b0263ffffffff60a01b19929097166001600160a01b0319909416939093171694909417919091169190911792909216919091179055565b6001600160a01b038316612a4e57610f60565b826001600160a01b031663e0409c7183836040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b158015612aa557600080fd5b505af1158015611985573d6000803e3d6000fd5b60008184841115612b0b5760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561285457818101518382015260200161283c565b505050900390565b60408051608081018252600080825260208201819052918101829052606081019190915290565b828054828255906000526020600020908101928215612b8f579160200282015b82811115612b8f57825182546001600160a01b0319166001600160a01b03909116178255602090920191600190910190612b5a565b50612b9b929150612be6565b5090565b828054828255906000526020600020908101928215612bda579160200282015b82811115612bda578251825591602001919060010190612bbf565b50612b9b929150612c05565b5b80821115612b9b5780546001600160a01b0319168155600101612be7565b5b80821115612b9b5760008155600101612c0656fe466173745072696365466565643a20696e76616c6964205f70726963654475726174696f6e466173745072696365466565643a20696e76616c69642063756d756c61746976654661737444656c7461476f7665726e61626c653a20666f7262696464656e0000000000000000000000466173745072696365466565643a20666f7262696464656e0000000000000000466173745072696365466565643a205f74696d657374616d70206578636565647320616c6c6f7765642072616e6765536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77466173745072696365466565643a205f74696d657374616d702062656c6f7720616c6c6f7765642072616e6765466173745072696365466565643a206d696e426c6f636b496e74657276616c206e6f742079657420706173736564466173745072696365466565643a20696e76616c69642063756d756c617469766552656644656c7461466173745072696365466565643a20616c726561647920696e697469616c697a6564a2646970667358221220641157aa9127bce25f284444f67be88534a16b4adf88cba3335342b11bf80a1164736f6c634300060c0033466173745072696365466565643a20696e76616c6964205f70726963654475726174696f6e000000000000000000000000000000000000000000000000000000000000012c0000000000000000000000000000000000000000000000000000000000000e10000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000fa0000000000000000000000009ecc5fb346fb505aec98179548c870511fd2b8c90000000000000000000000001197d7e9ace3eac4392690cf8d4f28e213dfe441
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106102e55760003560e01c806372279ba11161018f57806372279ba11461077c57806374bfed89146107c8578063776d16c1146107d0578063782661bc146107ed5780637cb2b79c146109125780637df73e27146109385780637fbc79c61461095e5780637fece36814610a88578063807c9782146103e357806382553aad14610abc5780638b7677f414610ad957806395082d2514610af6578063a2b47c1614610afe578063a374242514610b06578063a6eca89614610b2c578063b0a2566614610b34578063b3606b5614610b3c578063b70c7b7014610b44578063c8390a4814610b61578063c84a912414610c84578063cab44b7614610c8c578063ce98dfa814610cea578063cfad57a214610d09578063cfed246b14610d2f578063d6a153f114610d55578063d925351a14610d72578063de0d1b9414610d8f578063dfb481c914610dac578063e64559ad14610db4578063e68a22c014610dbc578063eeaa783a14610dc4578063f90ce5ba14610dcc576102e5565b806303b04936146102ea57806303cd25711461032457806303f4d7dc1461033e5780630604ddea146103e35780630e9272ea146103eb578063126082cf1461040f57806312d43a511461041757806314dd2dce1461041f578063162ac4e01461043c57806317835d1c146104625780631a15339114610485578063238aafb7146104b3578063287800c9146104d95780632a709b14146104e15780632e9cd94b146104e957806331cb61051461050657806332e5f9fa14610534578063392e53cd1461057e5780633aa08f861461058657806344c231931461058e5780634bd66c1c146103e35780634c0e31c8146105ab5780634d11fb4a146106ce5780634f64b2be146106eb5780634fdfb0861461070857806354aea1271461072e578063668d3d6514610736578063695d41841461073e5780636c56fd05146107465780636ccd47c41461076c578063715c753614610774575b600080fd5b6103106004803603602081101561030057600080fd5b50356001600160a01b0316610dd4565b604080519115158252519081900360200190f35b61032c610de9565b60408051918252519081900360200190f35b6103e16004803603604081101561035457600080fd5b810190602081018135600160201b81111561036e57600080fd5b82018360208201111561038057600080fd5b803590602001918460208302840111600160201b831117156103a157600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295505091359250610def915050565b005b61032c610f66565b6103f3610f6e565b604080516001600160a01b039092168252519081900360200190f35b61032c610f7d565b6103f3610f83565b6103e16004803603602081101561043557600080fd5b5035610f92565b6103e16004803603602081101561045257600080fd5b50356001600160a01b0316610fe4565b6103e16004803603604081101561047857600080fd5b5080359060200135611053565b6103e16004803603604081101561049b57600080fd5b506001600160a01b03813516906020013515156110af565b6103e1600480360360208110156104c957600080fd5b50356001600160a01b0316611127565b61032c611196565b6103f361119c565b6103e1600480360360208110156104ff57600080fd5b50356111ab565b6103e16004803603604081101561051c57600080fd5b506001600160a01b03813516906020013515156111fd565b6103e1600480360360e081101561054a57600080fd5b506001600160a01b038135169060208101359060408101359060608101359060808101359060a08101359060c00135611275565b61031061147d565b61032c61148d565b6103e1600480360360208110156105a457600080fd5b5035611493565b6103e1600480360360408110156105c157600080fd5b810190602081018135600160201b8111156105db57600080fd5b8201836020820111156105ed57600080fd5b803590602001918460208302840111600160201b8311171561060e57600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b81111561065d57600080fd5b82018360208201111561066f57600080fd5b803590602001918460208302840111600160201b8311171561069057600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611526945050505050565b61032c600480360360208110156106e457600080fd5b50356115d1565b6103f36004803603602081101561070157600080fd5b50356115ef565b6103106004803603602081101561071e57600080fd5b50356001600160a01b0316611616565b61032c61162b565b61032c611631565b610310611637565b6103106004803603602081101561075c57600080fd5b50356001600160a01b0316611647565b6103e16116d2565b61032c6117e5565b6107a26004803603602081101561079257600080fd5b50356001600160a01b03166117eb565b604080519485526020850193909352838301919091526060830152519081900360800190f35b61032c611869565b6103e1600480360360208110156107e657600080fd5b503561186f565b6103e16004803603606081101561080357600080fd5b810190602081018135600160201b81111561081d57600080fd5b82018360208201111561082f57600080fd5b803590602001918460208302840111600160201b8311171561085057600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b81111561089f57600080fd5b8201836020820111156108b157600080fd5b803590602001918460208302840111600160201b831117156108d257600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955050913592506118c1915050565b6103e16004803603602081101561092857600080fd5b50356001600160a01b031661198f565b6103106004803603602081101561094e57600080fd5b50356001600160a01b03166119fe565b6103e16004803603606081101561097457600080fd5b81359190810190604081016020820135600160201b81111561099557600080fd5b8201836020820111156109a757600080fd5b803590602001918460208302840111600160201b831117156109c857600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b811115610a1757600080fd5b820183602082011115610a2957600080fd5b803590602001918460208302840111600160201b83111715610a4a57600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611a13945050505050565b61032c60048036036060811015610a9e57600080fd5b506001600160a01b0381351690602081013590604001351515611b6c565b6103e160048036036020811015610ad257600080fd5b5035611cf2565b6103e160048036036020811015610aef57600080fd5b5035611d44565b61032c611d96565b61032c611da6565b61032c60048036036020811015610b1c57600080fd5b50356001600160a01b0316611dad565b61032c611dbf565b61032c611dc5565b61032c611dcb565b6103e160048036036020811015610b5a57600080fd5b5035611dd1565b6103e160048036036040811015610b7757600080fd5b810190602081018135600160201b811115610b9157600080fd5b820183602082011115610ba357600080fd5b803590602001918460208302840111600160201b83111715610bc457600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295949360208101935035915050600160201b811115610c1357600080fd5b820183602082011115610c2557600080fd5b803590602001918460208302840111600160201b83111715610c4657600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550611e23945050505050565b6103e1611eed565b610cb260048036036020811015610ca257600080fd5b50356001600160a01b0316612004565b604080516001600160a01b03909516855263ffffffff9384166020860152918316848301529091166060830152519081900360800190f35b6103e160048036036020811015610d0057600080fd5b50351515612043565b6103e160048036036020811015610d1f57600080fd5b50356001600160a01b03166120ae565b61032c60048036036020811015610d4557600080fd5b50356001600160a01b031661211d565b6103e160048036036020811015610d6b57600080fd5b503561212f565b6103e160048036036020811015610d8857600080fd5b5035612181565b6103e160048036036020811015610da557600080fd5b50356121d3565b61032c612225565b61032c61222b565b61032c612231565b6103f361223c565b61032c61224b565b60156020526000908152604090205460ff1681565b60065481565b3360009081526010602052604090205460ff16610e41576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b6000610e4c82612251565b90508015610f60576002546001546001600160a01b03918216911660005b8551811015610f5c576000868281518110610e8157fe5b6020026020010151905060005b6008811015610f5257601654600884028201908110610eb35750505050505050610f62565b60168054602084029185831c63ffffffff169160009190600889028701908110610ed957fe5b6000918252602082200154601780546001600160a01b0390921693509060088a028801908110610f0557fe5b60009182526020822001549150610f3282610f2c8668327cb2734119d3b7a9601e1b61235d565b906123bf565b9050610f4083828c8e6123fe565b505060019094019350610e8e92505050565b5050600101610e6a565b5050505b505b5050565b63ffffffff81565b6002546001600160a01b031681565b61271081565b6000546001600160a01b031681565b6000546001600160a01b03163314610fdf576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600455565b6000546001600160a01b03163314611031576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600280546001600160a01b0319166001600160a01b0392909216919091179055565b3360009081526010602052604090205460ff166110a5576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b610f628282612693565b6000546001600160a01b031633146110fc576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152601060205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314611174576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600180546001600160a01b0319166001600160a01b0392909216919091179055565b600e5481565b6003546001600160a01b031681565b6003546001600160a01b031633146111f8576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600c55565b6000546001600160a01b0316331461124a576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152601460205260409020805460ff1916911515919091179055565b3360009081526010602052604090205460ff166112c7576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b6112d18686612693565b6000879050600061134984836001600160a01b0316639b5786206040518163ffffffff1660e01b8152600401602060405180830381600087803b15801561131757600080fd5b505af115801561132b573d6000803e3d6000fd5b505050506040513d602081101561134157600080fd5b505190612769565b9050600061138c84846001600160a01b0316631bca8cf06040518163ffffffff1660e01b8152600401602060405180830381600087803b15801561131757600080fd5b90508187111561139a578196505b808611156113a6578095505b60408051629a208160e81b81526004810189905233602482015290516001600160a01b03851691639a20810091604480830192600092919082900301818387803b1580156113f357600080fd5b505af1158015611407573d6000803e3d6000fd5b50506040805163f3883d8b60e01b8152600481018a905233602482015290516001600160a01b038716935063f3883d8b9250604480830192600092919082900301818387803b15801561145957600080fd5b505af115801561146d573d6000803e3d6000fd5b5050505050505050505050505050565b600054600160a01b900460ff1681565b600b5481565b6000546001600160a01b031633146114e0576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b6107088111156115215760405162461bcd60e51b8152600401808060200182810382526025815260200180612c1b6025913960400191505060405180910390fd5b600655565b6003546001600160a01b03163314611573576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b60005b8251811015610f6057600083828151811061158d57fe5b602002602001015190508282815181106115a357fe5b6020908102919091018101516001600160a01b03909216600090815260139091526040902055600101611576565b601781815481106115de57fe5b600091825260209091200154905081565b601681815481106115fc57fe5b6000918252602090912001546001600160a01b0316905081565b60106020526000908152604090205460ff1681565b60045481565b61070881565b600054600160a81b900460ff1681565b60008054600160a81b900460ff1615611662575060006116cd565b600e54600f5410611675575060006116cd565b600080611681846117eb565b93509350505081811180156116b657506001600160a01b0384166000908152601360205260409020546116b482846127c1565b115b156116c6576000925050506116cd565b6001925050505b919050565b3360009081526014602052604090205460ff16611724576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b3360009081526015602052604090205460ff16611788576040805162461bcd60e51b815260206004820152601e60248201527f466173745072696365466565643a20616c726561647920656e61626c65640000604482015290519081900360640190fd5b336000908152601560205260409020805460ff19169055600f546117ad9060016127c1565b600f556040805133815290517f9fe0c305c33aa92757a537936872a60be0d91549a4303cc99fd8b7fce8a002759181900360200190a1565b600d5481565b6000806000806117f9612b13565b505050506001600160a01b039182166000908152601260209081526040918290208251608081018452905494851680825263ffffffff600160a01b87048116938301849052600160c01b87048116948301859052600160e01b909604909516606090910181905293949093919250565b60085481565b6000546001600160a01b031633146118bc576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600b55565b3360009081526010602052604090205460ff16611913576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600061191e82612251565b90508015611989576002546001546001600160a01b03918216911660005b865181101561198557600087828151811061195357fe5b6020026020010151905061197c8188848151811061196d57fe5b602002602001015185876123fe565b5060010161193c565b5050505b50505050565b6003546001600160a01b031633146119dc576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600380546001600160a01b0319166001600160a01b0392909216919091179055565b60146020526000908152604090205460ff1681565b6000546001600160a01b03163314611a60576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600054600160a01b900460ff1615611aa95760405162461bcd60e51b8152600401808060200182810382526022815260200180612d7e6022913960400191505060405180910390fd5b6000805460ff60a01b1916600160a01b178155600e8490555b8251811015611b15576000838281518110611ad957fe5b6020908102919091018101516001600160a01b03166000908152601490915260409020805460ff19166001908117909155919091019050611ac2565b5060005b8151811015611989576000828281518110611b3057fe5b6020908102919091018101516001600160a01b03166000908152601090915260409020805460ff19166001908117909155919091019050611b19565b6000611b8560075460045461276990919063ffffffff16565b421115611be0578115611bc057611bb9612710610f2c611bb260095461271061276990919063ffffffff16565b869061235d565b9050611ceb565b611bb9612710610f2c611bb26009546127106127c190919063ffffffff16565b600654600454611bef91612769565b421115611c3c578115611c1c57611bb9612710610f2c611bb260085461271061276990919063ffffffff16565b611bb9612710610f2c611bb26008546127106127c190919063ffffffff16565b6001600160a01b03841660009081526011602052604090205480611c635783915050611ceb565b6000818511611c7b57611c7682866127c1565b611c85565b611c8585836127c1565b9050611c9785610f2c8361271061235d565b90506000611ca487611647565b1580611cb15750600d5482115b90508015611ce5578415611cd857828611611ccc5782611cce565b855b9350505050611ceb565b828610611ccc5782611cce565b50909150505b9392505050565b6003546001600160a01b03163314611d3f576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600d55565b6000546001600160a01b03163314611d91576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600755565b68327cb2734119d3b7a9601e1b81565b6298968081565b60136020526000908152604090205481565b60095481565b600f5481565b600a5481565b6000546001600160a01b03163314611e1e576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600855565b6000546001600160a01b03163314611e70576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b8051825114611ec6576040805162461bcd60e51b815260206004820152601e60248201527f466173745072696365466565643a20696e76616c6964206c656e677468730000604482015290519081900360640190fd5b8151611ed9906016906020850190612b3a565b508051610f60906017906020840190612b9f565b3360009081526014602052604090205460ff16611f3f576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b3360009081526015602052604090205460ff1615611fa3576040805162461bcd60e51b815260206004820152601c60248201527b11985cdd141c9a58d9519959590e88185b1c9958591e481d9bdd195960221b604482015290519081900360640190fd5b336000908152601560205260409020805460ff19166001908117909155600f54611fcc91612769565b600f556040805133815290517f4c0c5fabf50e808e3bc8d19577d305e3a7163eea7e8a74a50caa8896694cd44b9181900360200190a1565b6012602052600090815260409020546001600160a01b0381169063ffffffff600160a01b8204811691600160c01b8104821691600160e01b9091041684565b6000546001600160a01b03163314612090576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b60008054911515600160a81b0260ff60a81b19909216919091179055565b6000546001600160a01b031633146120fb576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600080546001600160a01b0319166001600160a01b0392909216919091179055565b60116020526000908152604090205481565b6000546001600160a01b0316331461217c576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600a55565b6003546001600160a01b031633146121ce576040805162461bcd60e51b81526020600482015260186024820152600080516020612c8a833981519152604482015290519081900360640190fd5b600e55565b6000546001600160a01b03163314612220576040805162461bcd60e51b81526020600482015260156024820152600080516020612c6a833981519152604482015290519081900360640190fd5b600955565b600c5481565b60075481565b6001600160a01b0381565b6001546001600160a01b031681565b60055481565b600a54600090156122aa57600a5460055461226d9043906127c1565b10156122aa5760405162461bcd60e51b815260040180806020018281038252602e815260200180612d27602e913960400191505060405180910390fd5b600b546122b742826127c1565b83116122f45760405162461bcd60e51b815260040180806020018281038252602d815260200180612cfa602d913960400191505060405180910390fd5b6122fe4282612769565b831061233b5760405162461bcd60e51b815260040180806020018281038252602f815260200180612caa602f913960400191505060405180910390fd5b60045483101561234f5760009150506116cd565b505060045543600555600190565b60008261236c575060006123b9565b8282028284828161237957fe5b04146123b65760405162461bcd60e51b8152600401808060200182810382526021815260200180612cd96021913960400191505060405180910390fd5b90505b92915050565b60006123b683836040518060400160405280601a815260200179536166654d6174683a206469766973696f6e206279207a65726f60301b815250612803565b6001600160a01b0382161561266d576000826001600160a01b03166356bf9de4866040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561245c57600080fd5b505afa158015612470573d6000803e3d6000fd5b505050506040513d602081101561248657600080fd5b50516001600160a01b0386166000908152601160205260408120549192508080806124b08a6117eb565b935093509350935060008411156125775760008487116124d9576124d485886127c1565b6124e3565b6124e387866127c1565b905060008a87116124fd576124f88b886127c1565b612507565b612507878c6127c1565b905061251e600c54426123bf90919063ffffffff16565b600c5461252c9087906123bf565b1461253a5760009350600092505b61255561254e87610f2c856298968061235d565b8590612769565b935061257261256b88610f2c846298968061235d565b8490612769565b925050505b81811180156125a657506001600160a01b038a166000908152601360205260409020546125a482846127c1565b115b1561260357604080516001600160a01b038c16815260208101889052808201879052606081018490526080810183905290517fe582322b389ad06b2bbf619cd6da3f16a288ec873ea0fa6df4d72f3d9480b4479181900360a00190a15b61260f8a8784846128a5565b604080516001600160a01b038c16815260208101889052808201879052606081018490526080810183905290517f23b9387f81fca646aac1dc4487ede045c65f5f7445482906565f01e05afdb3a89181900360a00190a15050505050505b6001600160a01b0384166000908152601160205260409020839055611989818585612a3b565b600061269e82612251565b90508015610f60576002546001546001600160a01b03918216911660005b6008811015610f5c57601654819081106126da575050505050610f62565b60168054602084029189831c63ffffffff169160009190869081106126fb57fe5b6000918252602082200154601780546001600160a01b039092169350908790811061272257fe5b6000918252602082200154915061274982610f2c8668327cb2734119d3b7a9601e1b61235d565b905061275783828a8c6123fe565b5050600190940193506126bc92505050565b6000828201838110156123b6576040805162461bcd60e51b815260206004820152601b60248201527a536166654d6174683a206164646974696f6e206f766572666c6f7760281b604482015290519081900360640190fd5b60006123b683836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612ab9565b6000818361288f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561285457818101518382015260200161283c565b50505050905090810190601f1680156128815780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50600083858161289b57fe5b0495945050505050565b6001600160a01b038310612900576040805162461bcd60e51b815260206004820152601f60248201527f466173745072696365466565643a20696e76616c696420726566507269636500604482015290519081900360640190fd5b63ffffffff82106129425760405162461bcd60e51b8152600401808060200182810382526029815260200180612d556029913960400191505060405180910390fd5b63ffffffff81106129845760405162461bcd60e51b815260040180806020018281038252602a815260200180612c40602a913960400191505060405180910390fd5b604080516080810182526001600160a01b03948516815263ffffffff4281166020808401918252958216838501908152948216606084019081529787166000908152601290965292909420905181549251935196518516600160e01b026001600160e01b03978616600160c01b0263ffffffff60c01b1995909616600160a01b0263ffffffff60a01b19929097166001600160a01b0319909416939093171694909417919091169190911792909216919091179055565b6001600160a01b038316612a4e57610f60565b826001600160a01b031663e0409c7183836040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b158015612aa557600080fd5b505af1158015611985573d6000803e3d6000fd5b60008184841115612b0b5760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561285457818101518382015260200161283c565b505050900390565b60408051608081018252600080825260208201819052918101829052606081019190915290565b828054828255906000526020600020908101928215612b8f579160200282015b82811115612b8f57825182546001600160a01b0319166001600160a01b03909116178255602090920191600190910190612b5a565b50612b9b929150612be6565b5090565b828054828255906000526020600020908101928215612bda579160200282015b82811115612bda578251825591602001919060010190612bbf565b50612b9b929150612c05565b5b80821115612b9b5780546001600160a01b0319168155600101612be7565b5b80821115612b9b5760008155600101612c0656fe466173745072696365466565643a20696e76616c6964205f70726963654475726174696f6e466173745072696365466565643a20696e76616c69642063756d756c61746976654661737444656c7461476f7665726e61626c653a20666f7262696464656e0000000000000000000000466173745072696365466565643a20666f7262696464656e0000000000000000466173745072696365466565643a205f74696d657374616d70206578636565647320616c6c6f7765642072616e6765536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77466173745072696365466565643a205f74696d657374616d702062656c6f7720616c6c6f7765642072616e6765466173745072696365466565643a206d696e426c6f636b496e74657276616c206e6f742079657420706173736564466173745072696365466565643a20696e76616c69642063756d756c617469766552656644656c7461466173745072696365466565643a20616c726561647920696e697469616c697a6564a2646970667358221220641157aa9127bce25f284444f67be88534a16b4adf88cba3335342b11bf80a1164736f6c634300060c0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000000000000000000000000000000000000000012c0000000000000000000000000000000000000000000000000000000000000e10000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000fa0000000000000000000000009ecc5fb346fb505aec98179548c870511fd2b8c90000000000000000000000001197d7e9ace3eac4392690cf8d4f28e213dfe441
-----Decoded View---------------
Arg [0] : _priceDuration (uint256): 300
Arg [1] : _maxPriceUpdateDelay (uint256): 3600
Arg [2] : _minBlockInterval (uint256): 1
Arg [3] : _maxDeviationBasisPoints (uint256): 250
Arg [4] : _fastPriceEvents (address): 0x9ECc5fB346fb505AEC98179548c870511fD2b8C9
Arg [5] : _tokenManager (address): 0x1197d7E9acE3eaC4392690cF8d4f28E213DfE441
-----Encoded View---------------
6 Constructor Arguments found :
Arg [0] : 000000000000000000000000000000000000000000000000000000000000012c
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000e10
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000001
Arg [3] : 00000000000000000000000000000000000000000000000000000000000000fa
Arg [4] : 0000000000000000000000009ecc5fb346fb505aec98179548c870511fd2b8c9
Arg [5] : 0000000000000000000000001197d7e9ace3eac4392690cf8d4f28e213dfe441
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.