Contract Overview
My Name Tag:
Not Available, login to update
[ Download CSV Export ]
Latest 25 internal transaction
[ Download CSV Export ]
This contract may be a proxy contract. Click on More Options and select Is this a proxy? to confirm and enable the "Read as Proxy" & "Write as Proxy" tabs.
Contract Name:
StrategyBenqiDai
Compiler Version
v0.6.7+commit.b8d736ae
Contract Source Code (Solidity)
/** *Submitted for verification at snowtrace.io on 2021-11-06 */ // Sources flattened with hardhat v2.4.1 https://hardhat.org // File contracts/lib/safe-math.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; /** * @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; } } // File contracts/lib/context.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address payable) { return msg.sender; } function _msgData() internal view virtual returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } // File contracts/lib/erc20.sol // File: contracts/GSN/Context.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; // File: contracts/token/ERC20/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); /** * @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); /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); } // File: contracts/utils/Address.sol /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; // solhint-disable-next-line no-inline-assembly assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return _functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); return _functionCallWithValue(target, data, value, errorMessage); } function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) { require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: weiValue }(data); if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } // File: contracts/token/ERC20/ERC20.sol /** * @dev Implementation of the {IERC20} interface. * * This implementation is agnostic to the way tokens are created. This means * that a supply mechanism has to be added in a derived contract using {_mint}. * For a generic mechanism see {ERC20PresetMinterPauser}. * * TIP: For a detailed writeup see our guide * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How * to implement supply mechanisms]. * * We have followed general OpenZeppelin guidelines: functions revert instead * of returning `false` on failure. This behavior is nonetheless conventional * and does not conflict with the expectations of ERC20 applications. * * Additionally, an {Approval} event is emitted on calls to {transferFrom}. * This allows applications to reconstruct the allowance for all accounts just * by listening to said events. Other implementations of the EIP may not emit * these events, as it isn't required by the specification. * * Finally, the non-standard {decreaseAllowance} and {increaseAllowance} * functions have been added to mitigate the well-known issues around setting * allowances. See {IERC20-approve}. */ contract ERC20 is Context, IERC20 { using SafeMath for uint256; using Address for address; mapping (address => uint256) private _balances; mapping (address => mapping (address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; uint8 private _decimals; /** * @dev Sets the values for {name} and {symbol}, initializes {decimals} with * a default value of 18. * * To select a different value for {decimals}, use {_setupDecimals}. * * All three of these values are immutable: they can only be set once during * construction. */ constructor (string memory name, string memory symbol) public { _name = name; _symbol = symbol; _decimals = 18; } /** * @dev Returns the name of the token. */ function name() public view returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5,05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the value {ERC20} uses, unless {_setupDecimals} is * called. * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view returns (uint8) { return _decimals; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view override returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view override returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `recipient` cannot be the zero address. * - the caller must have a balance of at least `amount`. */ function transfer(address recipient, uint256 amount) public virtual override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual override returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 amount) public virtual override returns (bool) { _approve(_msgSender(), spender, amount); return true; } /** * @dev See {IERC20-transferFrom}. * * Emits an {Approval} event indicating the updated allowance. This is not * required by the EIP. See the note at the beginning of {ERC20}; * * Requirements: * - `sender` and `recipient` cannot be the zero address. * - `sender` must have a balance of at least `amount`. * - the caller must have allowance for ``sender``'s tokens of at least * `amount`. */ function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance")); return true; } /** * @dev Atomically increases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. */ function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue)); return true; } /** * @dev Atomically decreases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. * - `spender` must have allowance for the caller of at least * `subtractedValue`. */ function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero")); return true; } /** * @dev Moves tokens `amount` from `sender` to `recipient`. * * This is internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * Requirements: * * - `sender` cannot be the zero address. * - `recipient` cannot be the zero address. * - `sender` must have a balance of at least `amount`. */ function _transfer(address sender, address recipient, uint256 amount) internal virtual { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); _beforeTokenTransfer(sender, recipient, amount); _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance"); _balances[recipient] = _balances[recipient].add(amount); emit Transfer(sender, recipient, amount); } /** @dev Creates `amount` tokens and assigns them to `account`, increasing * the total supply. * * Emits a {Transfer} event with `from` set to the zero address. * * Requirements * * - `to` cannot be the zero address. */ function _mint(address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: mint to the zero address"); _beforeTokenTransfer(address(0), account, amount); _totalSupply = _totalSupply.add(amount); _balances[account] = _balances[account].add(amount); emit Transfer(address(0), account, amount); } /** * @dev Destroys `amount` tokens from `account`, reducing the * total supply. * * Emits a {Transfer} event with `to` set to the zero address. * * Requirements * * - `account` cannot be the zero address. * - `account` must have at least `amount` tokens. */ function _burn(address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: burn from the zero address"); _beforeTokenTransfer(account, address(0), amount); _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance"); _totalSupply = _totalSupply.sub(amount); emit Transfer(account, address(0), amount); } /** * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. */ function _approve(address owner, address spender, uint256 amount) internal virtual { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } /** * @dev Sets {decimals} to a value other than the default one of 18. * * WARNING: This function should only be called from the constructor. Most * applications that interact with token contracts will not expect * {decimals} to ever change, and may work incorrectly if it does. */ function _setupDecimals(uint8 decimals_) internal { _decimals = decimals_; } /** * @dev Hook that is called before any transfer of tokens. This includes * minting and burning. * * Calling conditions: * * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens * will be to transferred to `to`. * - when `from` is zero, `amount` tokens will be minted for `to`. * - when `to` is zero, `amount` of ``from``'s tokens will be burned. * - `from` and `to` are never both zero. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { } } /** * @title SafeERC20 * @dev Wrappers around ERC20 operations that throw on failure (when the token * contract returns false). Tokens that return no value (and instead revert or * throw on failure) are also supported, non-reverting calls are assumed to be * successful. * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract, * which allows you to call the safe operations as `token.safeTransfer(...)`, etc. */ library SafeERC20 { using SafeMath for uint256; using Address for address; function safeTransfer(IERC20 token, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value)); } function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value)); } /** * @dev Deprecated. This function has issues similar to the ones found in * {IERC20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove(IERC20 token, address spender, uint256 value) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' // solhint-disable-next-line max-line-length require((value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value)); } function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).add(value); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).sub(value, "SafeERC20: decreased allowance below zero"); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function _callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that // the target address contains contract code and also asserts for success in the low-level call. bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed"); if (returndata.length > 0) { // Return data is optional // solhint-disable-next-line max-line-length require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed"); } } } // File contracts/lib/careful-math.sol pragma solidity ^0.6.0; /** * @title Careful Math * @author Compound * @notice Derived from OpenZeppelin's SafeMath library * https://github.com/OpenZeppelin/openzeppelin-solidity/blob/master/contracts/math/SafeMath.sol */ contract CarefulMath { /** * @dev Possible error codes that we can return */ enum MathError { NO_ERROR, DIVISION_BY_ZERO, INTEGER_OVERFLOW, INTEGER_UNDERFLOW } /** * @dev Multiplies two numbers, returns an error on overflow. */ function mulUInt(uint a, uint b) internal pure returns (MathError, uint) { if (a == 0) { return (MathError.NO_ERROR, 0); } uint c = a * b; if (c / a != b) { return (MathError.INTEGER_OVERFLOW, 0); } else { return (MathError.NO_ERROR, c); } } /** * @dev Integer division of two numbers, truncating the quotient. */ function divUInt(uint a, uint b) internal pure returns (MathError, uint) { if (b == 0) { return (MathError.DIVISION_BY_ZERO, 0); } return (MathError.NO_ERROR, a / b); } /** * @dev Subtracts two numbers, returns an error on overflow (i.e. if subtrahend is greater than minuend). */ function subUInt(uint a, uint b) internal pure returns (MathError, uint) { if (b <= a) { return (MathError.NO_ERROR, a - b); } else { return (MathError.INTEGER_UNDERFLOW, 0); } } /** * @dev Adds two numbers, returns an error on overflow. */ function addUInt(uint a, uint b) internal pure returns (MathError, uint) { uint c = a + b; if (c >= a) { return (MathError.NO_ERROR, c); } else { return (MathError.INTEGER_OVERFLOW, 0); } } /** * @dev add a and b and then subtract c */ function addThenSubUInt(uint a, uint b, uint c) internal pure returns (MathError, uint) { (MathError err0, uint sum) = addUInt(a, b); if (err0 != MathError.NO_ERROR) { return (err0, 0); } return subUInt(sum, c); } } // File contracts/lib/exponential.sol pragma solidity ^0.6.0; /** * @title Exponential module for storing fixed-precision decimals * @author Compound * @notice Exp is a struct which stores decimals with a fixed precision of 18 decimal places. * Thus, if we wanted to store the 5.1, mantissa would store 5.1e18. That is: * `Exp({mantissa: 5100000000000000000})`. */ contract Exponential is CarefulMath { uint constant expScale = 1e18; uint constant doubleScale = 1e36; uint constant halfExpScale = expScale/2; uint constant mantissaOne = expScale; struct Exp { uint mantissa; } struct Double { uint mantissa; } /** * @dev Creates an exponential from numerator and denominator values. * Note: Returns an error if (`num` * 10e18) > MAX_INT, * or if `denom` is zero. */ function getExp(uint num, uint denom) pure internal returns (MathError, Exp memory) { (MathError err0, uint scaledNumerator) = mulUInt(num, expScale); if (err0 != MathError.NO_ERROR) { return (err0, Exp({mantissa: 0})); } (MathError err1, uint rational) = divUInt(scaledNumerator, denom); if (err1 != MathError.NO_ERROR) { return (err1, Exp({mantissa: 0})); } return (MathError.NO_ERROR, Exp({mantissa: rational})); } /** * @dev Adds two exponentials, returning a new exponential. */ function addExp(Exp memory a, Exp memory b) pure internal returns (MathError, Exp memory) { (MathError error, uint result) = addUInt(a.mantissa, b.mantissa); return (error, Exp({mantissa: result})); } /** * @dev Subtracts two exponentials, returning a new exponential. */ function subExp(Exp memory a, Exp memory b) pure internal returns (MathError, Exp memory) { (MathError error, uint result) = subUInt(a.mantissa, b.mantissa); return (error, Exp({mantissa: result})); } /** * @dev Multiply an Exp by a scalar, returning a new Exp. */ function mulScalar(Exp memory a, uint scalar) pure internal returns (MathError, Exp memory) { (MathError err0, uint scaledMantissa) = mulUInt(a.mantissa, scalar); if (err0 != MathError.NO_ERROR) { return (err0, Exp({mantissa: 0})); } return (MathError.NO_ERROR, Exp({mantissa: scaledMantissa})); } /** * @dev Multiply an Exp by a scalar, then truncate to return an unsigned integer. */ function mulScalarTruncate(Exp memory a, uint scalar) pure internal returns (MathError, uint) { (MathError err, Exp memory product) = mulScalar(a, scalar); if (err != MathError.NO_ERROR) { return (err, 0); } return (MathError.NO_ERROR, truncate(product)); } /** * @dev Multiply an Exp by a scalar, truncate, then add an to an unsigned integer, returning an unsigned integer. */ function mulScalarTruncateAddUInt(Exp memory a, uint scalar, uint addend) pure internal returns (MathError, uint) { (MathError err, Exp memory product) = mulScalar(a, scalar); if (err != MathError.NO_ERROR) { return (err, 0); } return addUInt(truncate(product), addend); } /** * @dev Divide an Exp by a scalar, returning a new Exp. */ function divScalar(Exp memory a, uint scalar) pure internal returns (MathError, Exp memory) { (MathError err0, uint descaledMantissa) = divUInt(a.mantissa, scalar); if (err0 != MathError.NO_ERROR) { return (err0, Exp({mantissa: 0})); } return (MathError.NO_ERROR, Exp({mantissa: descaledMantissa})); } /** * @dev Divide a scalar by an Exp, returning a new Exp. */ function divScalarByExp(uint scalar, Exp memory divisor) pure internal returns (MathError, Exp memory) { /* We are doing this as: getExp(mulUInt(expScale, scalar), divisor.mantissa) How it works: Exp = a / b; Scalar = s; `s / (a / b)` = `b * s / a` and since for an Exp `a = mantissa, b = expScale` */ (MathError err0, uint numerator) = mulUInt(expScale, scalar); if (err0 != MathError.NO_ERROR) { return (err0, Exp({mantissa: 0})); } return getExp(numerator, divisor.mantissa); } /** * @dev Divide a scalar by an Exp, then truncate to return an unsigned integer. */ function divScalarByExpTruncate(uint scalar, Exp memory divisor) pure internal returns (MathError, uint) { (MathError err, Exp memory fraction) = divScalarByExp(scalar, divisor); if (err != MathError.NO_ERROR) { return (err, 0); } return (MathError.NO_ERROR, truncate(fraction)); } /** * @dev Multiplies two exponentials, returning a new exponential. */ function mulExp(Exp memory a, Exp memory b) pure internal returns (MathError, Exp memory) { (MathError err0, uint doubleScaledProduct) = mulUInt(a.mantissa, b.mantissa); if (err0 != MathError.NO_ERROR) { return (err0, Exp({mantissa: 0})); } // We add half the scale before dividing so that we get rounding instead of truncation. // See "Listing 6" and text above it at https://accu.org/index.php/journals/1717 // Without this change, a result like 6.6...e-19 will be truncated to 0 instead of being rounded to 1e-18. (MathError err1, uint doubleScaledProductWithHalfScale) = addUInt(halfExpScale, doubleScaledProduct); if (err1 != MathError.NO_ERROR) { return (err1, Exp({mantissa: 0})); } (MathError err2, uint product) = divUInt(doubleScaledProductWithHalfScale, expScale); // The only error `div` can return is MathError.DIVISION_BY_ZERO but we control `expScale` and it is not zero. assert(err2 == MathError.NO_ERROR); return (MathError.NO_ERROR, Exp({mantissa: product})); } /** * @dev Multiplies two exponentials given their mantissas, returning a new exponential. */ function mulExp(uint a, uint b) pure internal returns (MathError, Exp memory) { return mulExp(Exp({mantissa: a}), Exp({mantissa: b})); } /** * @dev Multiplies three exponentials, returning a new exponential. */ function mulExp3(Exp memory a, Exp memory b, Exp memory c) pure internal returns (MathError, Exp memory) { (MathError err, Exp memory ab) = mulExp(a, b); if (err != MathError.NO_ERROR) { return (err, ab); } return mulExp(ab, c); } /** * @dev Divides two exponentials, returning a new exponential. * (a/scale) / (b/scale) = (a/scale) * (scale/b) = a/b, * which we can scale as an Exp by calling getExp(a.mantissa, b.mantissa) */ function divExp(Exp memory a, Exp memory b) pure internal returns (MathError, Exp memory) { return getExp(a.mantissa, b.mantissa); } /** * @dev Truncates the given exp to a whole number value. * For example, truncate(Exp{mantissa: 15 * expScale}) = 15 */ function truncate(Exp memory exp) pure internal returns (uint) { // Note: We are not using careful math here as we're performing a division that cannot fail return exp.mantissa / expScale; } /** * @dev Checks if first Exp is less than second Exp. */ function lessThanExp(Exp memory left, Exp memory right) pure internal returns (bool) { return left.mantissa < right.mantissa; } /** * @dev Checks if left Exp <= right Exp. */ function lessThanOrEqualExp(Exp memory left, Exp memory right) pure internal returns (bool) { return left.mantissa <= right.mantissa; } /** * @dev Checks if left Exp > right Exp. */ function greaterThanExp(Exp memory left, Exp memory right) pure internal returns (bool) { return left.mantissa > right.mantissa; } /** * @dev returns true if Exp is exactly zero */ function isZeroExp(Exp memory value) pure internal returns (bool) { return value.mantissa == 0; } function safe224(uint n, string memory errorMessage) pure internal returns (uint224) { require(n < 2**224, errorMessage); return uint224(n); } function safe32(uint n, string memory errorMessage) pure internal returns (uint32) { require(n < 2**32, errorMessage); return uint32(n); } function add_(Exp memory a, Exp memory b) pure internal returns (Exp memory) { return Exp({mantissa: add_(a.mantissa, b.mantissa)}); } function add_(Double memory a, Double memory b) pure internal returns (Double memory) { return Double({mantissa: add_(a.mantissa, b.mantissa)}); } function add_(uint a, uint b) pure internal returns (uint) { return add_(a, b, "addition overflow"); } function add_(uint a, uint b, string memory errorMessage) pure internal returns (uint) { uint c = a + b; require(c >= a, errorMessage); return c; } function sub_(Exp memory a, Exp memory b) pure internal returns (Exp memory) { return Exp({mantissa: sub_(a.mantissa, b.mantissa)}); } function sub_(Double memory a, Double memory b) pure internal returns (Double memory) { return Double({mantissa: sub_(a.mantissa, b.mantissa)}); } function sub_(uint a, uint b) pure internal returns (uint) { return sub_(a, b, "subtraction underflow"); } function sub_(uint a, uint b, string memory errorMessage) pure internal returns (uint) { require(b <= a, errorMessage); return a - b; } function mul_(Exp memory a, Exp memory b) pure internal returns (Exp memory) { return Exp({mantissa: mul_(a.mantissa, b.mantissa) / expScale}); } function mul_(Exp memory a, uint b) pure internal returns (Exp memory) { return Exp({mantissa: mul_(a.mantissa, b)}); } function mul_(uint a, Exp memory b) pure internal returns (uint) { return mul_(a, b.mantissa) / expScale; } function mul_(Double memory a, Double memory b) pure internal returns (Double memory) { return Double({mantissa: mul_(a.mantissa, b.mantissa) / doubleScale}); } function mul_(Double memory a, uint b) pure internal returns (Double memory) { return Double({mantissa: mul_(a.mantissa, b)}); } function mul_(uint a, Double memory b) pure internal returns (uint) { return mul_(a, b.mantissa) / doubleScale; } function mul_(uint a, uint b) pure internal returns (uint) { return mul_(a, b, "multiplication overflow"); } function mul_(uint a, uint b, string memory errorMessage) pure internal returns (uint) { if (a == 0 || b == 0) { return 0; } uint c = a * b; require(c / a == b, errorMessage); return c; } function div_(Exp memory a, Exp memory b) pure internal returns (Exp memory) { return Exp({mantissa: div_(mul_(a.mantissa, expScale), b.mantissa)}); } function div_(Exp memory a, uint b) pure internal returns (Exp memory) { return Exp({mantissa: div_(a.mantissa, b)}); } function div_(uint a, Exp memory b) pure internal returns (uint) { return div_(mul_(a, expScale), b.mantissa); } function div_(Double memory a, Double memory b) pure internal returns (Double memory) { return Double({mantissa: div_(mul_(a.mantissa, doubleScale), b.mantissa)}); } function div_(Double memory a, uint b) pure internal returns (Double memory) { return Double({mantissa: div_(a.mantissa, b)}); } function div_(uint a, Double memory b) pure internal returns (uint) { return div_(mul_(a, doubleScale), b.mantissa); } function div_(uint a, uint b) pure internal returns (uint) { return div_(a, b, "divide by zero"); } function div_(uint a, uint b, string memory errorMessage) pure internal returns (uint) { require(b > 0, errorMessage); return a / b; } function fraction(uint a, uint b) pure internal returns (Double memory) { return Double({mantissa: div_(mul_(a, doubleScale), b)}); } } // File contracts/interfaces/globe.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.2; interface IGlobe is IERC20 { function token() external view returns (address); function claimInsurance() external; // NOTE: Only yDelegatedVault implements this function getRatio() external view returns (uint256); function depositAll() external; function deposit(uint256) external; function withdrawAll() external; function withdraw(uint256) external; function earn() external; function decimals() external view returns (uint8); } // File contracts/interfaces/staking-rewards.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.2; interface IStakingRewards { function balanceOf(address account) external view returns (uint256); function earned(address account) external view returns (uint256); function exit() external; function getReward() external; function getRewardForDuration() external view returns (uint256); function lastTimeRewardApplicable() external view returns (uint256); function lastUpdateTime() external view returns (uint256); function notifyRewardAmount(uint256 reward) external; function periodFinish() external view returns (uint256); function rewardPerToken() external view returns (uint256); function rewardPerTokenStored() external view returns (uint256); function rewardRate() external view returns (uint256); function rewards(address) external view returns (uint256); function rewardsDistribution() external view returns (address); function rewardsDuration() external view returns (uint256); function rewardsToken() external view returns (address); function stake(uint256 amount) external; function stakeWithPermit( uint256 amount, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; function stakingToken() external view returns (address); function totalSupply() external view returns (uint256); function userRewardPerTokenPaid(address) external view returns (uint256); function withdraw(uint256 amount) external; } interface IStakingRewardsFactory { function deploy(address stakingToken, uint256 rewardAmount) external; function isOwner() external view returns (bool); function notifyRewardAmount(address stakingToken) external; function notifyRewardAmounts() external; function owner() external view returns (address); function renounceOwnership() external; function rewardsToken() external view returns (address); function stakingRewardsGenesis() external view returns (uint256); function stakingRewardsInfoByStakingToken(address) external view returns (address stakingRewards, uint256 rewardAmount); function stakingTokens(uint256) external view returns (address); function transferOwnership(address newOwner) external; } // File contracts/interfaces/icequeen.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.7; interface IIcequeen { function BONUS_MULTIPLIER() external view returns (uint256); function add( uint256 _allocPoint, address _lpToken, bool _withUpdate ) external; function bonusEndBlock() external view returns (uint256); function deposit(uint256 _pid, uint256 _amount) external; function dev(address _devaddr) external; function devFundDivRate() external view returns (uint256); function devaddr() external view returns (address); function emergencyWithdraw(uint256 _pid) external; function getMultiplier(uint256 _from, uint256 _to) external view returns (uint256); function massUpdatePools() external; function owner() external view returns (address); function pendingSnowball(uint256 _pid, address _user) external view returns (uint256); function snowball() external view returns (address); function snowballPerBlock() external view returns (uint256); function poolInfo(uint256) external view returns ( address lpToken, uint256 allocPoint, uint256 lastRewardBlock, uint256 accSnowballPerShare ); function poolLength() external view returns (uint256); function renounceOwnership() external; function set( uint256 _pid, uint256 _allocPoint, bool _withUpdate ) external; function setBonusEndBlock(uint256 _bonusEndBlock) external; function setDevFundDivRate(uint256 _devFundDivRate) external; function setSnowballPerBlock(uint256 _snowballPerBlock) external; function startBlock() external view returns (uint256); function totalAllocPoint() external view returns (uint256); function transferOwnership(address newOwner) external; function updatePool(uint256 _pid) external; function userInfo(uint256, address) external view returns (uint256 amount, uint256 rewardDebt); function withdraw(uint256 _pid, uint256 _amount) external; } // File contracts/interfaces/pangolin.sol // SPDX-License-Identifier: MIT // SPDX-License-Identifier: MIT pragma solidity ^0.6.2; interface IPangolinRouter { function swapExactTokensForTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns ( uint256 amountA, uint256 amountB, uint256 liquidity ); function addLiquidityAVAX( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountAVAXMin, address to, uint256 deadline ) external payable returns ( uint256 amountToken, uint256 amountAVAX, uint256 liquidity ); function removeLiquidity( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB); function getAmountsOut(uint256 amountIn, address[] calldata path) external view returns (uint256[] memory amounts); function getAmountsIn(uint256 amountOut, address[] calldata path) external view returns (uint256[] memory amounts); function swapAVAXForExactTokens( uint256 amountOut, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapExactAVAXForTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); } interface IPangolinPair { event Approval( address indexed owner, address indexed spender, uint256 value ); event Transfer(address indexed from, address indexed to, uint256 value); function name() external pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure returns (uint8); function totalSupply() external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transfer(address to, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); function DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint256); function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; event Mint(address indexed sender, uint256 amount0, uint256 amount1); event Burn( address indexed sender, uint256 amount0, uint256 amount1, address indexed to ); event Swap( address indexed sender, uint256 amount0In, uint256 amount1In, uint256 amount0Out, uint256 amount1Out, address indexed to ); event Sync(uint112 reserve0, uint112 reserve1); function MINIMUM_LIQUIDITY() external pure returns (uint256); function factory() external view returns (address); function token0() external view returns (address); function token1() external view returns (address); function getReserves() external view returns ( uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast ); function price0CumulativeLast() external view returns (uint256); function price1CumulativeLast() external view returns (uint256); function kLast() external view returns (uint256); function mint(address to) external returns (uint256 liquidity); function burn(address to) external returns (uint256 amount0, uint256 amount1); function swap( uint256 amount0Out, uint256 amount1Out, address to, bytes calldata data ) external; function skim(address to) external; function sync() external; } interface IPangolinFactory { event PairCreated( address indexed token0, address indexed token1, address pair, uint256 ); function getPair(address tokenA, address tokenB) external view returns (address pair); function allPairs(uint256) external view returns (address pair); function allPairsLength() external view returns (uint256); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function createPair(address tokenA, address tokenB) external returns (address pair); } // File contracts/interfaces/controller.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; interface IController { function globes(address) external view returns (address); function rewards() external view returns (address); function devfund() external view returns (address); function treasury() external view returns (address); function balanceOf(address) external view returns (uint256); function withdraw(address, uint256) external; function earn(address, uint256) external; } // File contracts/strategies/strategy-base.sol pragma solidity ^0.6.7; // Strategy Contract Basics abstract contract StrategyBase { using SafeERC20 for IERC20; using Address for address; using SafeMath for uint256; // Tokens address public want; address public constant wavax = 0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7; address public constant png = 0x60781C2586D68229fde47564546784ab3fACA982; // Dex address public pangolinRouter = 0xE54Ca86531e17Ef3616d22Ca28b0D458b6C89106; // Move ^^ // Perfomance fees - start with 10% uint256 public performanceTreasuryFee = 1000; uint256 public constant performanceTreasuryMax = 10000; uint256 public performanceDevFee = 0; uint256 public constant performanceDevMax = 10000; // Withdrawal fee 0% // - 0% to treasury // - 0% to dev fund uint256 public withdrawalTreasuryFee = 0; uint256 public constant withdrawalTreasuryMax = 100000; uint256 public withdrawalDevFundFee = 0; uint256 public constant withdrawalDevFundMax = 100000; // User accounts address public governance; address public controller; address public strategist; address public timelock; mapping(address => bool) public harvesters; constructor( address _want, address _governance, address _strategist, address _controller, address _timelock ) public { require(_want != address(0)); require(_governance != address(0)); require(_strategist != address(0)); require(_controller != address(0)); require(_timelock != address(0)); want = _want; governance = _governance; strategist = _strategist; controller = _controller; timelock = _timelock; } // **** Modifiers **** // modifier onlyBenevolent { require( harvesters[msg.sender] || msg.sender == governance || msg.sender == strategist ); _; } // **** Views **** // function balanceOfWant() public view returns (uint256) { return IERC20(want).balanceOf(address(this)); } function balanceOfPool() public virtual view returns (uint256); function balanceOf() public view returns (uint256) { return balanceOfWant().add(balanceOfPool()); } function getName() external virtual pure returns (string memory); // **** Setters **** // function whitelistHarvester(address _harvester) external { require(msg.sender == governance || msg.sender == strategist, "not authorized"); harvesters[_harvester] = true; } function revokeHarvester(address _harvester) external { require(msg.sender == governance || msg.sender == strategist, "not authorized"); harvesters[_harvester] = false; } function setWithdrawalDevFundFee(uint256 _withdrawalDevFundFee) external { require(msg.sender == timelock, "!timelock"); withdrawalDevFundFee = _withdrawalDevFundFee; } function setWithdrawalTreasuryFee(uint256 _withdrawalTreasuryFee) external { require(msg.sender == timelock, "!timelock"); withdrawalTreasuryFee = _withdrawalTreasuryFee; } function setPerformanceDevFee(uint256 _performanceDevFee) external { require(msg.sender == timelock, "!timelock"); performanceDevFee = _performanceDevFee; } function setPerformanceTreasuryFee(uint256 _performanceTreasuryFee) external { require(msg.sender == timelock, "!timelock"); performanceTreasuryFee = _performanceTreasuryFee; } function setStrategist(address _strategist) external { require(msg.sender == governance, "!governance"); strategist = _strategist; } function setGovernance(address _governance) external { require(msg.sender == governance, "!governance"); governance = _governance; } function setTimelock(address _timelock) external { require(msg.sender == timelock, "!timelock"); timelock = _timelock; } function setController(address _controller) external { require(msg.sender == timelock, "!timelock"); controller = _controller; } // **** State mutations **** // function deposit() public virtual; // Controller only function for creating additional rewards from dust function withdraw(IERC20 _asset) external returns (uint256 balance) { require(msg.sender == controller, "!controller"); require(want != address(_asset), "want"); balance = _asset.balanceOf(address(this)); _asset.safeTransfer(controller, balance); } // Withdraw partial funds, normally used with a globe withdrawal function withdraw(uint256 _amount) external { require(msg.sender == controller, "!controller"); uint256 _balance = IERC20(want).balanceOf(address(this)); if (_balance < _amount) { _amount = _withdrawSome(_amount.sub(_balance)); _amount = _amount.add(_balance); } uint256 _feeDev = _amount.mul(withdrawalDevFundFee).div( withdrawalDevFundMax ); IERC20(want).safeTransfer(IController(controller).devfund(), _feeDev); uint256 _feeTreasury = _amount.mul(withdrawalTreasuryFee).div( withdrawalTreasuryMax ); IERC20(want).safeTransfer( IController(controller).treasury(), _feeTreasury ); address _globe = IController(controller).globes(address(want)); require(_globe != address(0), "!globe"); // additional protection so we don't burn the funds IERC20(want).safeTransfer(_globe, _amount.sub(_feeDev).sub(_feeTreasury)); } // Withdraw funds, used to swap between strategies function withdrawForSwap(uint256 _amount) external returns (uint256 balance) { require(msg.sender == controller, "!controller"); _withdrawSome(_amount); balance = IERC20(want).balanceOf(address(this)); address _globe = IController(controller).globes(address(want)); require(_globe != address(0), "!globe"); IERC20(want).safeTransfer(_globe, balance); } // Withdraw all funds, normally used when migrating strategies function withdrawAll() external returns (uint256 balance) { require(msg.sender == controller, "!controller"); _withdrawAll(); balance = IERC20(want).balanceOf(address(this)); address _globe = IController(controller).globes(address(want)); require(_globe != address(0), "!globe"); // additional protection so we don't burn the funds IERC20(want).safeTransfer(_globe, balance); } function _withdrawAll() internal { _withdrawSome(balanceOfPool()); } function _withdrawSome(uint256 _amount) internal virtual returns (uint256); function harvest() public virtual; // **** Emergency functions **** function execute(address _target, bytes memory _data) public payable returns (bytes memory response) { require(msg.sender == timelock, "!timelock"); require(_target != address(0), "!target"); // call contract in current context assembly { let succeeded := delegatecall( sub(gas(), 5000), _target, add(_data, 0x20), mload(_data), 0, 0 ) let size := returndatasize() response := mload(0x40) mstore( 0x40, add(response, and(add(add(size, 0x20), 0x1f), not(0x1f))) ) mstore(response, size) returndatacopy(add(response, 0x20), 0, size) switch iszero(succeeded) case 1 { // throw if delegatecall failed revert(add(response, 0x20), size) } } } // **** Internal functions **** function _swapPangolin( address _from, address _to, uint256 _amount ) internal { require(_to != address(0)); // Swap with Pangolin IERC20(_from).safeApprove(pangolinRouter, 0); IERC20(_from).safeApprove(pangolinRouter, _amount); address[] memory path; if (_from == png || _to == png) { path = new address[](2); path[0] = _from; path[1] = _to; } else if (_from == wavax || _to == wavax) { path = new address[](2); path[0] = _from; path[1] = _to; } else { path = new address[](3); path[0] = _from; path[1] = png; path[2] = _to; } IPangolinRouter(pangolinRouter).swapExactTokensForTokens( _amount, 0, path, address(this), now.add(60) ); } function _swapPangolinWithPath( address[] memory path, uint256 _amount ) internal { require(path[1] != address(0)); IPangolinRouter(pangolinRouter).swapExactTokensForTokens( _amount, 0, path, address(this), now.add(60) ); } function _distributePerformanceFeesAndDeposit() internal { uint256 _want = IERC20(want).balanceOf(address(this)); if (_want > 0) { // Treasury fees IERC20(want).safeTransfer( IController(controller).treasury(), _want.mul(performanceTreasuryFee).div(performanceTreasuryMax) ); // Performance fee IERC20(want).safeTransfer( IController(controller).devfund(), _want.mul(performanceDevFee).div(performanceDevMax) ); deposit(); } } } // File contracts/interfaces/benqi.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; interface IQiToken { function totalSupply() external view returns (uint256); function totalBorrows() external returns (uint256); function borrowIndex() external returns (uint256); function repayBorrow(uint256 repayAmount) external returns (uint256); function redeemUnderlying(uint256 redeemAmount) external returns (uint256); function borrow(uint256 borrowAmount) external returns (uint256); function mint(uint256 mintAmount) external returns (uint256); function transfer(address dst, uint256 amount) external returns (bool); function transferFrom( address src, address dst, uint256 amount ) external returns (bool); function approve(address spender, uint256 amount) external returns (bool); function allowance(address owner, address spender) external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function balanceOfUnderlying(address owner) external returns (uint256); function getAccountSnapshot(address account) external view returns ( uint256, uint256, uint256, uint256 ); function borrowRatePerBlock() external view returns (uint256); function supplyRatePerBlock() external view returns (uint256); function totalBorrowsCurrent() external returns (uint256); function borrowBalanceCurrent(address account) external returns (uint256); function borrowBalanceStored(address account) external view returns (uint256); function exchangeRateCurrent() external returns (uint256); function exchangeRateStored() external view returns (uint256); function getCash() external view returns (uint256); function accrueInterest() external returns (uint256); function seize( address liquidator, address borrower, uint256 seizeTokens ) external returns (uint256); } interface IQiAvax { function mint() external payable; /** * @notice Sender redeems qiTokens in exchange for the underlying asset * @dev Accrues interest whether or not the operation succeeds, unless reverted * @param redeemTokens The number of qiTokens to redeem into underlying * @return uint 0=success, otherwise a failure (see ErrorReporter.sol for details) */ function redeem(uint256 redeemTokens) external returns (uint256); /** * @notice Sender redeems qiTokens in exchange for a specified amount of underlying asset * @dev Accrues interest whether or not the operation succeeds, unless reverted * @param redeemAmount The amount of underlying to redeem * @return uint 0=success, otherwise a failure (see ErrorReporter.sol for details) */ function redeemUnderlying(uint256 redeemAmount) external returns (uint256); /** * @notice Sender borrows assets from the protocol to their own address * @param borrowAmount The amount of the underlying asset to borrow * @return uint 0=success, otherwise a failure (see ErrorReporter.sol for details) */ function borrow(uint256 borrowAmount) external returns (uint256); /** * @notice Sender repays their own borrow * @dev Reverts upon any failure */ function repayBorrow() external payable; /** * @notice Sender repays a borrow belonging to borrower * @dev Reverts upon any failure * @param borrower the account with the debt being payed off */ function repayBorrowBehalf(address borrower) external payable; /** * @notice The sender liquidates the borrowers collateral. * The collateral seized is transferred to the liquidator. * @dev Reverts upon any failure * @param borrower The borrower of this qiToken to be liquidated * @param qiTokenCollateral The market in which to seize collateral from the borrower */ function liquidateBorrow(address borrower, address qiTokenCollateral) external payable; } interface IComptroller { function compAccrued(address) external view returns (uint256); function compSupplierIndex(address, address) external view returns (uint256); function compBorrowerIndex(address, address) external view returns (uint256); function compSpeeds(address) external view returns (uint256); function compBorrowState(address) external view returns (uint224, uint32); function compSupplyState(address) external view returns (uint224, uint32); /*** Assets You Are In ***/ function enterMarkets(address[] calldata qiTokens) external returns (uint256[] memory); function exitMarket(address qiToken) external returns (uint256); /*** Policy Hooks ***/ function mintAllowed( address qiToken, address minter, uint256 mintAmount ) external returns (uint256); function mintVerify( address qiToken, address minter, uint256 mintAmount, uint256 mintTokens ) external; function redeemAllowed( address qiToken, address redeemer, uint256 redeemTokens ) external returns (uint256); function redeemVerify( address qiToken, address redeemer, uint256 redeemAmount, uint256 redeemTokens ) external; function borrowAllowed( address qiToken, address borrower, uint256 borrowAmount ) external returns (uint256); function borrowVerify( address qiToken, address borrower, uint256 borrowAmount ) external; function repayBorrowAllowed( address qiToken, address payer, address borrower, uint256 repayAmount ) external returns (uint256); function repayBorrowVerify( address qiToken, address payer, address borrower, uint256 repayAmount, uint256 borrowerIndex ) external; function liquidateBorrowAllowed( address qiTokenBorrowed, address qiTokenCollateral, address liquidator, address borrower, uint256 repayAmount ) external returns (uint256); function liquidateBorrowVerify( address qiTokenBorrowed, address qiTokenCollateral, address liquidator, address borrower, uint256 repayAmount, uint256 seizeTokens ) external; function seizeAllowed( address qiTokenCollateral, address qiTokenBorrowed, address liquidator, address borrower, uint256 seizeTokens ) external returns (uint256); function seizeVerify( address qiTokenCollateral, address qiTokenBorrowed, address liquidator, address borrower, uint256 seizeTokens ) external; function transferAllowed( address qiToken, address src, address dst, uint256 transferTokens ) external returns (uint256); function transferVerify( address qiToken, address src, address dst, uint256 transferTokens ) external; /*** Liquidity/Liquidation Calculations ***/ function liquidateCalculateSeizeTokens( address qiTokenBorrowed, address qiTokenCollateral, uint256 repayAmount ) external view returns (uint256, uint256); // Claim all the Qi accrued by holder in all markets function claimReward(uint8 rewardId, address holder) external; // Claim all the Qi accrued by holder in specific markets function claimReward(uint8 rewardId, address holder, address[] calldata qiTokens) external; // Claim all the Qi accrued by specific holders in specific markets for their supplies and/or borrows function claimReward(uint8 rewardId, address[] calldata holders, address[] calldata qiTokens, bool borrowers, bool suppliers ) external; function markets(address qiTokenAddress) external view returns (bool, uint256); } interface IBenqiLens { function getQiBalanceMetadataExt( address qi, address comptroller, address account ) external returns ( uint256 balance, uint256 votes, address delegate, uint256 allocated ); } // File contracts/interfaces/wavax.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.0; interface WAVAX { function name() external view returns (string memory); function approve(address guy, uint256 wad) external returns (bool); function totalSupply() external view returns (uint256); function transferFrom( address src, address dst, uint256 wad ) external returns (bool); function withdraw(uint256 wad) external; function decimals() external view returns (uint8); function balanceOf(address) external view returns (uint256); function symbol() external view returns (string memory); function transfer(address dst, uint256 wad) external returns (bool); function deposit() external payable; function allowance(address, address) external view returns (uint256); } // File contracts/strategies/benqi/strategy-benqi-daie.sol // SPDX-License-Identifier: MIT pragma solidity ^0.6.2; contract StrategyBenqiDai is StrategyBase, Exponential { address public constant comptroller = 0x486Af39519B4Dc9a7fCcd318217352830E8AD9b4; // Through UniTroller Address address public constant dai = 0xd586E7F844cEa2F87f50152665BCbc2C279D8d70; //qideposit token address public constant benqi = 0x8729438EB15e2C8B576fCc6AeCdA6A148776C0F5; //Qi Token address public constant qidai = 0x835866d37AFB8CB8F8334dCCdaf66cf01832Ff5D; //lending receipt token // Require a 0.04 buffer between // market collateral factor and strategy's collateral factor // when leveraging. uint256 colFactorLeverageBuffer = 40; uint256 colFactorLeverageBufferMax = 1000; // Allow a 0.03 buffer // between market collateral factor and strategy's collateral factor // until we have to deleverage // This is so we can hit max leverage and keep accruing interest uint256 colFactorSyncBuffer = 30; uint256 colFactorSyncBufferMax = 1000; // Keeper bots // Maintain leverage within buffer mapping(address => bool) keepers; constructor( address _governance, address _strategist, address _controller, address _timelock ) public StrategyBase(dai, _governance, _strategist, _controller, _timelock) { // Enter qiDAI Market address[] memory qitokens = new address[](1); qitokens[0] = qidai; IComptroller(comptroller).enterMarkets(qitokens); } // **** Modifiers **** // modifier onlyKeepers { require( keepers[msg.sender] || msg.sender == address(this) || msg.sender == strategist || msg.sender == governance, "!keepers" ); _; } // **** Views **** // function getName() external override pure returns (string memory) { return "StrategyBenqiDai"; } function getSuppliedView() public view returns (uint256) { (, uint256 qiTokenBal, , uint256 exchangeRate) = IQiToken(qidai) .getAccountSnapshot(address(this)); (, uint256 bal) = mulScalarTruncate( Exp({mantissa: exchangeRate}), qiTokenBal ); return bal; } function getBorrowedView() public view returns (uint256) { return IQiToken(qidai).borrowBalanceStored(address(this)); } function balanceOfPool() public override view returns (uint256) { uint256 supplied = getSuppliedView(); uint256 borrowed = getBorrowedView(); return supplied.sub(borrowed); } // Given an unleveraged supply balance, return the target // leveraged supply balance which is still within the safety buffer function getLeveragedSupplyTarget(uint256 supplyBalance) public view returns (uint256) { uint256 leverage = getMaxLeverage(); return supplyBalance.mul(leverage).div(1e18); } function getSafeLeverageColFactor() public view returns (uint256) { uint256 colFactor = getMarketColFactor(); // Collateral factor within the buffer uint256 safeColFactor = colFactor.sub( colFactorLeverageBuffer.mul(1e18).div(colFactorLeverageBufferMax) ); return safeColFactor; } function getSafeSyncColFactor() public view returns (uint256) { uint256 colFactor = getMarketColFactor(); // Collateral factor within the buffer uint256 safeColFactor = colFactor.sub( colFactorSyncBuffer.mul(1e18).div(colFactorSyncBufferMax) ); return safeColFactor; } function getMarketColFactor() public view returns (uint256) { (, uint256 colFactor) = IComptroller(comptroller).markets(qidai); return colFactor; } // Max leverage we can go up to, w.r.t safe buffer function getMaxLeverage() public view returns (uint256) { uint256 safeLeverageColFactor = getSafeLeverageColFactor(); // Infinite geometric series uint256 leverage = uint256(1e36).div(1e18 - safeLeverageColFactor); return leverage; } // **** Pseudo-view functions (use `callStatic` on these) **** // /* The reason why these exists is because of the nature of the interest accruing supply + borrow balance. The "view" methods are technically snapshots and don't represent the real value. As such there are pseudo view methods where you can retrieve the results by calling `callStatic`. */ function getColFactor() public returns (uint256) { uint256 supplied = getSupplied(); uint256 borrowed = getBorrowed(); return borrowed.mul(1e18).div(supplied); } function getSuppliedUnleveraged() public returns (uint256) { uint256 supplied = getSupplied(); uint256 borrowed = getBorrowed(); return supplied.sub(borrowed); } function getSupplied() public returns (uint256) { return IQiToken(qidai).balanceOfUnderlying(address(this)); } function getBorrowed() public returns (uint256) { return IQiToken(qidai).borrowBalanceCurrent(address(this)); } function getBorrowable() public returns (uint256) { uint256 supplied = getSupplied(); uint256 borrowed = getBorrowed(); (, uint256 colFactor) = IComptroller(comptroller).markets(qidai); // 99.99% just in case some dust accumulates return supplied.mul(colFactor).div(1e18).sub(borrowed).mul(9999).div( 10000 ); } function getRedeemable() public returns (uint256) { uint256 supplied = getSupplied(); uint256 borrowed = getBorrowed(); (, uint256 colFactor) = IComptroller(comptroller).markets(qidai); // Return 99.99% of the time just incase return supplied.sub(borrowed.mul(1e18).div(colFactor)).mul(9999).div( 10000 ); } function getCurrentLeverage() public returns (uint256) { uint256 supplied = getSupplied(); uint256 borrowed = getBorrowed(); return supplied.mul(1e18).div(supplied.sub(borrowed)); } // **** Setters **** // function addKeeper(address _keeper) public { require( msg.sender == governance || msg.sender == strategist, "!governance" ); keepers[_keeper] = true; } function removeKeeper(address _keeper) public { require( msg.sender == governance || msg.sender == strategist, "!governance" ); keepers[_keeper] = false; } function setColFactorLeverageBuffer(uint256 _colFactorLeverageBuffer) public { require( msg.sender == governance || msg.sender == strategist, "!governance" ); colFactorLeverageBuffer = _colFactorLeverageBuffer; } function setColFactorSyncBuffer(uint256 _colFactorSyncBuffer) public { require( msg.sender == governance || msg.sender == strategist, "!governance" ); colFactorSyncBuffer = _colFactorSyncBuffer; } // **** State mutations **** // // Do a `callStatic` on this. // If it returns true then run it for realz. (i.e. eth_signedTx, not eth_call) function sync() public returns (bool) { uint256 colFactor = getColFactor(); uint256 safeSyncColFactor = getSafeSyncColFactor(); // If we're not safe if (colFactor > safeSyncColFactor) { uint256 unleveragedSupply = getSuppliedUnleveraged(); uint256 idealSupply = getLeveragedSupplyTarget(unleveragedSupply); deleverageUntil(idealSupply); return true; } return false; } function leverageToMax() public { uint256 unleveragedSupply = getSuppliedUnleveraged(); uint256 idealSupply = getLeveragedSupplyTarget(unleveragedSupply); leverageUntil(idealSupply); } // Leverages until we're supplying <x> amount // 1. Redeem <x> DAI // 2. Repay <x> DAI function leverageUntil(uint256 _supplyAmount) public onlyKeepers { // 1. Borrow out <X> DAI // 2. Supply <X> DAI uint256 leverage = getMaxLeverage(); uint256 unleveragedSupply = getSuppliedUnleveraged(); require( _supplyAmount >= unleveragedSupply && _supplyAmount <= unleveragedSupply.mul(leverage).div(1e18), "!leverage" ); // Since we're only leveraging one asset // Supplied = borrowed uint256 _borrowAndSupply; uint256 supplied = getSupplied(); while (supplied < _supplyAmount) { _borrowAndSupply = getBorrowable(); if (supplied.add(_borrowAndSupply) > _supplyAmount) { _borrowAndSupply = _supplyAmount.sub(supplied); } IQiToken(qidai).borrow(_borrowAndSupply); deposit(); supplied = supplied.add(_borrowAndSupply); } } function deleverageToMin() public { uint256 unleveragedSupply = getSuppliedUnleveraged(); deleverageUntil(unleveragedSupply); } // Deleverages until we're supplying <x> amount // 1. Redeem <x> DAI // 2. Repay <x> DAI function deleverageUntil(uint256 _supplyAmount) public onlyKeepers { uint256 unleveragedSupply = getSuppliedUnleveraged(); uint256 supplied = getSupplied(); require( _supplyAmount >= unleveragedSupply && _supplyAmount <= supplied, "!deleverage" ); // Market collateral factor uint256 marketColFactor = getMarketColFactor(); // How much can we redeem uint256 _redeemAndRepay = getRedeemable(); do { // If the amount we're redeeming is exceeding the // target supplyAmount, adjust accordingly if (supplied.sub(_redeemAndRepay) < _supplyAmount) { _redeemAndRepay = supplied.sub(_supplyAmount); } require( IQiToken(qidai).redeemUnderlying(_redeemAndRepay) == 0, "!redeem" ); IERC20(dai).safeApprove(qidai, 0); IERC20(dai).safeApprove(qidai, _redeemAndRepay); require(IQiToken(qidai).repayBorrow(_redeemAndRepay) == 0, "!repay"); supplied = supplied.sub(_redeemAndRepay); // After each deleverage we can redeem more (the colFactor) _redeemAndRepay = _redeemAndRepay.mul(1e18).div(marketColFactor); } while (supplied > _supplyAmount); } // allow Native Avax receive() external payable {} function harvest() public override onlyBenevolent { address[] memory qitokens = new address[](1); qitokens[0] = qidai; IComptroller(comptroller).claimReward(0, address(this)); //ClaimQi uint256 _benqi = IERC20(benqi).balanceOf(address(this)); if (_benqi > 0) { _swapPangolin(benqi, want, _benqi); } IComptroller(comptroller).claimReward(1, address(this)); //ClaimAvax uint256 _avax = address(this).balance; //get balance of native Avax if (_avax > 0) { //wrap avax into ERC20 WAVAX(wavax).deposit{value: _avax}(); } uint256 _wavax = IERC20(wavax).balanceOf(address(this)); if (_wavax > 0) { _swapPangolin(wavax, want, _wavax); } _distributePerformanceFeesAndDeposit(); } function deposit() public override { uint256 _want = IERC20(want).balanceOf(address(this)); if (_want > 0) { IERC20(want).safeApprove(qidai, 0); IERC20(want).safeApprove(qidai, _want); require(IQiToken(qidai).mint(_want) == 0, "!deposit"); } } function _withdrawSome(uint256 _amount) internal override returns (uint256) { uint256 _want = balanceOfWant(); if (_want < _amount) { uint256 _redeem = _amount.sub(_want); // Make sure market can cover liquidity require(IQiToken(qidai).getCash() >= _redeem, "!cash-liquidity"); // How much borrowed amount do we need to free? uint256 borrowed = getBorrowed(); uint256 supplied = getSupplied(); uint256 curLeverage = getCurrentLeverage(); uint256 borrowedToBeFree = _redeem.mul(curLeverage).div(1e18); // If the amount we need to free is > borrowed // Just free up all the borrowed amount if (borrowedToBeFree > borrowed) { this.deleverageToMin(); } else { // Otherwise just keep freeing up borrowed amounts until // we hit a safe number to redeem our underlying this.deleverageUntil(supplied.sub(borrowedToBeFree)); } // Redeems underlying require(IQiToken(qidai).redeemUnderlying(_redeem) == 0, "!redeem"); } return _amount; } }
[{"inputs":[{"internalType":"address","name":"_governance","type":"address"},{"internalType":"address","name":"_strategist","type":"address"},{"internalType":"address","name":"_controller","type":"address"},{"internalType":"address","name":"_timelock","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"_keeper","type":"address"}],"name":"addKeeper","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"balanceOfPool","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"balanceOfWant","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"benqi","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"comptroller","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"controller","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dai","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deleverageToMin","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_supplyAmount","type":"uint256"}],"name":"deleverageUntil","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_target","type":"address"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"execute","outputs":[{"internalType":"bytes","name":"response","type":"bytes"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"getBorrowable","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getBorrowed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getBorrowedView","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getColFactor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getCurrentLeverage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"supplyBalance","type":"uint256"}],"name":"getLeveragedSupplyTarget","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMarketColFactor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMaxLeverage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getName","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"getRedeemable","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getSafeLeverageColFactor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getSafeSyncColFactor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getSupplied","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getSuppliedUnleveraged","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getSuppliedView","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"governance","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"harvest","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"harvesters","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"leverageToMax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_supplyAmount","type":"uint256"}],"name":"leverageUntil","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"pangolinRouter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"performanceDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"performanceDevMax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"performanceTreasuryFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"performanceTreasuryMax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"png","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"qidai","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_keeper","type":"address"}],"name":"removeKeeper","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_harvester","type":"address"}],"name":"revokeHarvester","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_colFactorLeverageBuffer","type":"uint256"}],"name":"setColFactorLeverageBuffer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_colFactorSyncBuffer","type":"uint256"}],"name":"setColFactorSyncBuffer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_controller","type":"address"}],"name":"setController","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_governance","type":"address"}],"name":"setGovernance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_performanceDevFee","type":"uint256"}],"name":"setPerformanceDevFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_performanceTreasuryFee","type":"uint256"}],"name":"setPerformanceTreasuryFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_strategist","type":"address"}],"name":"setStrategist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_timelock","type":"address"}],"name":"setTimelock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_withdrawalDevFundFee","type":"uint256"}],"name":"setWithdrawalDevFundFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_withdrawalTreasuryFee","type":"uint256"}],"name":"setWithdrawalTreasuryFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"strategist","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sync","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"timelock","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"want","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"wavax","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_harvester","type":"address"}],"name":"whitelistHarvester","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_asset","type":"address"}],"name":"withdraw","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawAll","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdrawForSwap","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawalDevFundFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawalDevFundMax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawalTreasuryFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawalTreasuryMax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
6080604052600180546001600160a01b03191673e54ca86531e17ef3616d22ca28b0d458b6c891061790556103e860028190556000600381905560048190556005556028600b55600c819055601e600d55600e553480156200006057600080fd5b50604051620040cf380380620040cf833981810160405260808110156200008657600080fd5b508051602082015160408301516060909301519192909173d586e7f844cea2f87f50152665bcbc2c279d8d70848484846001600160a01b038416620000ca57600080fd5b6001600160a01b038316620000de57600080fd5b6001600160a01b038216620000f257600080fd5b6001600160a01b0381166200010657600080fd5b600080546001600160a01b03199081166001600160a01b039788161790915560068054821695871695909517909455600880548516938616939093179092556007805484169185169190911790556009805490921692169190911790556040805160018082528183019092526060916020808301908036833701905050905073835866d37afb8cb8f8334dccdaf66cf01832ff5d81600081518110620001a857fe5b6001600160a01b03909216602092830291909101820152604051631853304760e31b81526004810182815283516024830152835173486af39519b4dc9a7fccd318217352830e8ad9b49363c2998238938693928392604490920191858101910280838360005b83811015620002285781810151838201526020016200020e565b5050505090500192505050600060405180830381600087803b1580156200024e57600080fd5b505af115801562000263573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405260208110156200028d57600080fd5b8101908080516040519392919084640100000000821115620002ae57600080fd5b908301906020820185811115620002c457600080fd5b8251866020820283011164010000000082111715620002e257600080fd5b82525081516020918201928201910280838360005b8381101562000311578181015183820152602001620002f7565b50505050905001604052505050505050505050613d9b80620003346000396000f3fe6080604052600436106103d25760003560e01c80635f775678116101fd578063ab033ea911610118578063d0e30db0116100ab578063f4b9fa751161007a578063f4b9fa7514610c22578063f53f135014610c37578063f77c479114610c4c578063fe1f8f7a14610761578063fff6cae914610c61576103d9565b8063d0e30db014610ba4578063d33219b414610bb9578063eb514af914610bce578063f4aa3a8d14610bf8576103d9565b8063c1a3d44c116100e7578063c1a3d44c14610b08578063c6223e2614610b1d578063c65e324214610b47578063c7b9d53014610b71576103d9565b8063ab033ea914610a63578063ab73e43314610a96578063ac41ceb314610ac0578063bdacb30314610ad5576103d9565b8063875cb38c1161019057806392eefe9b1161015f57806392eefe9b146109dc5780639c4b816314610a0f5780639eb52f6114610a24578063a1e003e414610a39576103d9565b8063875cb38c14610956578063879765831461096b57806388993f22146109b25780638ccdbb70146109c7576103d9565b806377da835a116101cc57806377da835a146108ed5780638081e1cf146109025780638237859414610917578063853828b614610941576103d9565b80635f775678146108995780635fe3b567146108ae578063722713f7146108c35780637396a626146108d8576103d9565b80634032b72b116102ed57806354df7b63116102805780635af0cd901161024f5780635af0cd90146108455780635bfb92ce1461085a5780635c2084901461086f5780635eefb09214610884576103d9565b806354df7b63146107be57806359739ec4146107f157806359bca679146108065780635aa6e67514610830576103d9565b8063479119be116102bc578063479119be146107615780634fe809cc1461065c57806351cff8d91461077657806351f3d0b8146107a9576103d9565b80634032b72b146106ef5780634465c1cc14610722578063463289ed146107375780634641257d1461074c576103d9565b80631f1fcd51116103655780632a99417d116103345780632a99417d146106715780632e1a7d4d14610686578063302ab80d146106b05780633c5dae94146106da576103d9565b80631f1fcd51146106085780631fe4a6861461061d578063249fb9b41461063257806326e886c61461065c576103d9565b806317d7de7c116103a157806317d7de7c1461048057806318284fc81461050a57806318eb0e0b1461051f5780631cff79cd14610552576103d9565b80630ea8b3bf146103de5780631158808614610405578063117be4c21461041a57806314ae9f2e1461044b576103d9565b366103d957005b600080fd5b3480156103ea57600080fd5b506103f3610c76565b60408051918252519081900360200190f35b34801561041157600080fd5b506103f3610cb7565b34801561042657600080fd5b5061042f610ce0565b604080516001600160a01b039092168252519081900360200190f35b34801561045757600080fd5b5061047e6004803603602081101561046e57600080fd5b50356001600160a01b0316610cf8565b005b34801561048c57600080fd5b50610495610d7b565b6040805160208082528351818301528351919283929083019185019080838360005b838110156104cf5781810151838201526020016104b7565b50505050905090810190601f1680156104fc5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561051657600080fd5b5061042f610da5565b34801561052b57600080fd5b5061047e6004803603602081101561054257600080fd5b50356001600160a01b0316610dbd565b6104956004803603604081101561056857600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561059357600080fd5b8201836020820111156105a557600080fd5b803590602001918460018302840111640100000000831117156105c757600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550610e43945050505050565b34801561061457600080fd5b5061042f610f26565b34801561062957600080fd5b5061042f610f35565b34801561063e57600080fd5b5061047e6004803603602081101561065557600080fd5b5035610f44565b34801561066857600080fd5b506103f3610f94565b34801561067d57600080fd5b506103f3610f9a565b34801561069257600080fd5b5061047e600480360360208110156106a957600080fd5b5035610fdb565b3480156106bc57600080fd5b5061047e600480360360208110156106d357600080fd5b5035611308565b3480156106e657600080fd5b506103f361136f565b3480156106fb57600080fd5b5061047e6004803603602081101561071257600080fd5b50356001600160a01b03166113b1565b34801561072e57600080fd5b5061042f611437565b34801561074357600080fd5b506103f3611449565b34801561075857600080fd5b5061047e6114e0565b34801561076d57600080fd5b506103f3611846565b34801561078257600080fd5b506103f36004803603602081101561079957600080fd5b50356001600160a01b031661184d565b3480156107b557600080fd5b506103f3611983565b3480156107ca57600080fd5b5061047e600480360360208110156107e157600080fd5b50356001600160a01b0316611989565b3480156107fd57600080fd5b506103f3611a12565b34801561081257600080fd5b5061047e6004803603602081101561082957600080fd5b5035611a18565b34801561083c57600080fd5b5061042f611a7f565b34801561085157600080fd5b5061042f611a8e565b34801561086657600080fd5b506103f3611a9d565b34801561087b57600080fd5b506103f3611ae1565b34801561089057600080fd5b506103f3611b62565b3480156108a557600080fd5b5061042f611bc5565b3480156108ba57600080fd5b5061042f611bdd565b3480156108cf57600080fd5b506103f3611bf5565b3480156108e457600080fd5b506103f3611c1b565b3480156108f957600080fd5b506103f3611c50565b34801561090e57600080fd5b506103f3611d02565b34801561092357600080fd5b5061047e6004803603602081101561093a57600080fd5b5035611d52565b34801561094d57600080fd5b506103f3611da2565b34801561096257600080fd5b506103f3611f59565b34801561097757600080fd5b5061099e6004803603602081101561098e57600080fd5b50356001600160a01b031661204c565b604080519115158252519081900360200190f35b3480156109be57600080fd5b506103f3612061565b3480156109d357600080fd5b506103f3612067565b3480156109e857600080fd5b5061047e600480360360208110156109ff57600080fd5b50356001600160a01b031661206d565b348015610a1b57600080fd5b506103f36120da565b348015610a3057600080fd5b506103f36120f1565b348015610a4557600080fd5b506103f360048036036020811015610a5c57600080fd5b50356121c4565b348015610a6f57600080fd5b5061047e60048036036020811015610a8657600080fd5b50356001600160a01b03166121f4565b348015610aa257600080fd5b5061047e60048036036020811015610ab957600080fd5b5035612263565b348015610acc57600080fd5b5061047e6122b3565b348015610ae157600080fd5b5061047e60048036036020811015610af857600080fd5b50356001600160a01b03166122d9565b348015610b1457600080fd5b506103f3612346565b348015610b2957600080fd5b506103f360048036036020811015610b4057600080fd5b5035612392565b348015610b5357600080fd5b5061047e60048036036020811015610b6a57600080fd5b503561254d565b348015610b7d57600080fd5b5061047e60048036036020811015610b9457600080fd5b50356001600160a01b031661259d565b348015610bb057600080fd5b5061047e61260c565b348015610bc557600080fd5b5061042f6127a6565b348015610bda57600080fd5b5061047e60048036036020811015610bf157600080fd5b50356127b5565b348015610c0457600080fd5b5061047e60048036036020811015610c1b57600080fd5b5035612afe565b348015610c2e57600080fd5b5061042f612ceb565b348015610c4357600080fd5b5061047e612d03565b348015610c5857600080fd5b5061042f612d18565b348015610c6d57600080fd5b5061099e612d27565b600080610c8161136f565b90506000610caf6ec097ce7bc90715b34b9f1000000000670de0b6b3a764000084900363ffffffff612d8016565b925050505b90565b600080610cc2611c50565b90506000610cce611b62565b9050610caf828263ffffffff612dcb16565b73b31f66aa3c1e785363f0875a1b74e27b85fd66c781565b6006546001600160a01b0316331480610d1b57506008546001600160a01b031633145b610d5a576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b6001600160a01b03166000908152600f60205260409020805460ff19169055565b60408051808201909152601081526f537472617465677942656e716944616960801b602082015290565b738729438eb15e2c8b576fcc6aecda6a148776c0f581565b6006546001600160a01b0316331480610de057506008546001600160a01b031633145b610e22576040805162461bcd60e51b815260206004820152600e60248201526d1b9bdd08185d5d1a1bdc9a5e995960921b604482015290519081900360640190fd5b6001600160a01b03166000908152600a60205260409020805460ff19169055565b6009546060906001600160a01b03163314610e91576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b6001600160a01b038316610ed6576040805162461bcd60e51b8152602060048201526007602482015266085d185c99d95d60ca1b604482015290519081900360640190fd5b600080835160208501866113885a03f43d6040519250601f19601f6020830101168301604052808352806000602085013e811560018114610f1657610f1d565b8160208501fd5b50505092915050565b6000546001600160a01b031681565b6008546001600160a01b031681565b6009546001600160a01b03163314610f8f576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600255565b61271081565b600080610fa5611ae1565b90506000610fb1611d02565b9050610caf82610fcf83670de0b6b3a764000063ffffffff612e0d16565b9063ffffffff612d8016565b6007546001600160a01b03163314611028576040805162461bcd60e51b815260206004820152600b60248201526a10b1b7b73a3937b63632b960a91b604482015290519081900360640190fd5b60008054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561107457600080fd5b505afa158015611088573d6000803e3d6000fd5b505050506040513d602081101561109e57600080fd5b50519050818110156110d7576110c26110bd838363ffffffff612dcb16565b612e66565b91506110d4828263ffffffff61311a16565b91505b60006110f5620186a0610fcf60055486612e0d90919063ffffffff16565b905061118d600760009054906101000a90046001600160a01b03166001600160a01b0316638d8f1e676040518163ffffffff1660e01b815260040160206040518083038186803b15801561114857600080fd5b505afa15801561115c573d6000803e3d6000fd5b505050506040513d602081101561117257600080fd5b50516000546001600160a01b0316908363ffffffff61317416565b60006111ab620186a0610fcf60045487612e0d90919063ffffffff16565b90506111fe600760009054906101000a90046001600160a01b03166001600160a01b03166361d027b36040518163ffffffff1660e01b815260040160206040518083038186803b15801561114857600080fd5b600754600080546040805163368da5ef60e11b81526001600160a01b039283166004820152905192939190911691636d1b4bde91602480820192602092909190829003018186803b15801561125257600080fd5b505afa158015611266573d6000803e3d6000fd5b505050506040513d602081101561127c57600080fd5b505190506001600160a01b0381166112c4576040805162461bcd60e51b815260206004820152600660248201526521676c6f626560d01b604482015290519081900360640190fd5b611301816112e8846112dc898863ffffffff612dcb16565b9063ffffffff612dcb16565b6000546001600160a01b0316919063ffffffff61317416565b5050505050565b6006546001600160a01b031633148061132b57506008546001600160a01b031633145b61136a576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b600b55565b60008061137a611449565b90506000610caf6113a4600c54610fcf670de0b6b3a7640000600b54612e0d90919063ffffffff16565b839063ffffffff612dcb16565b6006546001600160a01b03163314806113d457506008546001600160a01b031633145b611413576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b6001600160a01b03166000908152600f60205260409020805460ff19166001179055565b600080516020613ce683398151915281565b60408051638e8f294b60e01b8152600080516020613ce683398151915260048201528151600092839273486af39519b4dc9a7fccd318217352830e8ad9b492638e8f294b92602480840193919291829003018186803b1580156114ab57600080fd5b505afa1580156114bf573d6000803e3d6000fd5b505050506040513d60408110156114d557600080fd5b506020015191505090565b336000908152600a602052604090205460ff168061150857506006546001600160a01b031633145b8061151d57506008546001600160a01b031633145b61152657600080fd5b60408051600180825281830190925260609160208083019080368337019050509050600080516020613ce68339815191528160008151811061156457fe5b6001600160a01b039092166020928302919091019091015260408051630952c56360e01b8152600060048201819052306024830152915173486af39519b4dc9a7fccd318217352830e8ad9b492630952c563926044808201939182900301818387803b1580156115d357600080fd5b505af11580156115e7573d6000803e3d6000fd5b5050604080516370a0823160e01b8152306004820152905160009350738729438eb15e2c8b576fcc6aecda6a148776c0f592506370a0823191602480820192602092909190829003018186803b15801561164057600080fd5b505afa158015611654573d6000803e3d6000fd5b505050506040513d602081101561166a57600080fd5b5051905080156116a0576000546116a090738729438eb15e2c8b576fcc6aecda6a148776c0f5906001600160a01b0316836131cb565b60408051630952c56360e01b815260016004820152306024820152905173486af39519b4dc9a7fccd318217352830e8ad9b491630952c56391604480830192600092919082900301818387803b1580156116f957600080fd5b505af115801561170d573d6000803e3d6000fd5b5047925050811590506117835773b31f66aa3c1e785363f0875a1b74e27b85fd66c76001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b15801561176957600080fd5b505af115801561177d573d6000803e3d6000fd5b50505050505b604080516370a0823160e01b8152306004820152905160009173b31f66aa3c1e785363f0875a1b74e27b85fd66c7916370a0823191602480820192602092909190829003018186803b1580156117d857600080fd5b505afa1580156117ec573d6000803e3d6000fd5b505050506040513d602081101561180257600080fd5b505190508015611838576000546118389073b31f66aa3c1e785363f0875a1b74e27b85fd66c7906001600160a01b0316836131cb565b6118406135ae565b50505050565b620186a081565b6007546000906001600160a01b0316331461189d576040805162461bcd60e51b815260206004820152600b60248201526a10b1b7b73a3937b63632b960a91b604482015290519081900360640190fd5b6000546001600160a01b03838116911614156118e9576040805162461bcd60e51b815260206004808301919091526024820152631dd85b9d60e21b604482015290519081900360640190fd5b604080516370a0823160e01b815230600482015290516001600160a01b038416916370a08231916024808301926020929190829003018186803b15801561192f57600080fd5b505afa158015611943573d6000803e3d6000fd5b505050506040513d602081101561195957600080fd5b505160075490915061197e906001600160a01b0384811691168363ffffffff61317416565b919050565b60055481565b6006546001600160a01b03163314806119ac57506008546001600160a01b031633145b6119ee576040805162461bcd60e51b815260206004820152600e60248201526d1b9bdd08185d5d1a1bdc9a5e995960921b604482015290519081900360640190fd5b6001600160a01b03166000908152600a60205260409020805460ff19166001179055565b60025481565b6006546001600160a01b0316331480611a3b57506008546001600160a01b031633145b611a7a576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b600d55565b6006546001600160a01b031681565b6001546001600160a01b031681565b600080611aa8611ae1565b90506000611ab4611d02565b9050610caf611ac9838363ffffffff612dcb16565b610fcf84670de0b6b3a764000063ffffffff612e0d16565b60408051633af9e66960e01b81523060048201529051600091600080516020613ce683398151915291633af9e6699160248082019260209290919082900301818787803b158015611b3157600080fd5b505af1158015611b45573d6000803e3d6000fd5b505050506040513d6020811015611b5b57600080fd5b5051905090565b604080516395dd919360e01b81523060048201529051600091600080516020613ce6833981519152916395dd919391602480820192602092909190829003018186803b158015611bb157600080fd5b505afa158015611b45573d6000803e3d6000fd5b7360781c2586d68229fde47564546784ab3faca98281565b73486af39519b4dc9a7fccd318217352830e8ad9b481565b6000611c16611c02610cb7565b611c0a612346565b9063ffffffff61311a16565b905090565b600080611c26611449565b90506000610caf6113a4600e54610fcf670de0b6b3a7640000600d54612e0d90919063ffffffff16565b604080516361bfb47160e11b8152306004820152905160009182918291600080516020613ce68339815191529163c37f68e291602480820192608092909190829003018186803b158015611ca357600080fd5b505afa158015611cb7573d6000803e3d6000fd5b505050506040513d6080811015611ccd57600080fd5b50602080820151606090920151604080519283019052808252919350909150600090611cf99084613752565b94505050505090565b604080516305eff7ef60e21b81523060048201529051600091600080516020613ce6833981519152916317bfdfbc9160248082019260209290919082900301818787803b158015611b3157600080fd5b6009546001600160a01b03163314611d9d576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600455565b6007546000906001600160a01b03163314611df2576040805162461bcd60e51b815260206004820152600b60248201526a10b1b7b73a3937b63632b960a91b604482015290519081900360640190fd5b611dfa6137a6565b600054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015611e4557600080fd5b505afa158015611e59573d6000803e3d6000fd5b505050506040513d6020811015611e6f57600080fd5b5051600754600080546040805163368da5ef60e11b81526001600160a01b03928316600482015290519495509193921691636d1b4bde91602480820192602092909190829003018186803b158015611ec657600080fd5b505afa158015611eda573d6000803e3d6000fd5b505050506040513d6020811015611ef057600080fd5b505190506001600160a01b038116611f38576040805162461bcd60e51b815260206004820152600660248201526521676c6f626560d01b604482015290519081900360640190fd5b600054611f55906001600160a01b0316828463ffffffff61317416565b5090565b600080611f64611ae1565b90506000611f70611d02565b60408051638e8f294b60e01b8152600080516020613ce68339815191526004820152815192935060009273486af39519b4dc9a7fccd318217352830e8ad9b492638e8f294b9260248082019391829003018186803b158015611fd157600080fd5b505afa158015611fe5573d6000803e3d6000fd5b505050506040513d6040811015611ffb57600080fd5b50602001519050612044612710610fcf61270f61203861202b868489670de0b6b3a764000063ffffffff612e0d16565b889063ffffffff612dcb16565b9063ffffffff612e0d16565b935050505090565b600a6020526000908152604090205460ff1681565b60035481565b60045481565b6009546001600160a01b031633146120b8576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6000806120e5611ae1565b90506000610cce611d02565b6000806120fc611ae1565b90506000612108611d02565b60408051638e8f294b60e01b8152600080516020613ce68339815191526004820152815192935060009273486af39519b4dc9a7fccd318217352830e8ad9b492638e8f294b9260248082019391829003018186803b15801561216957600080fd5b505afa15801561217d573d6000803e3d6000fd5b505050506040513d604081101561219357600080fd5b50602001519050612044612710610fcf61270f612038866112dc670de0b6b3a7640000858b8a63ffffffff612e0d16565b6000806121cf610c76565b90506121ed670de0b6b3a7640000610fcf858463ffffffff612e0d16565b9392505050565b6006546001600160a01b03163314612241576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b600680546001600160a01b0319166001600160a01b0392909216919091179055565b6009546001600160a01b031633146122ae576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600555565b60006122bd6120da565b905060006122ca826121c4565b90506122d581612afe565b5050565b6009546001600160a01b03163314612324576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600980546001600160a01b0319166001600160a01b0392909216919091179055565b60008054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015611bb157600080fd5b6007546000906001600160a01b031633146123e2576040805162461bcd60e51b815260206004820152600b60248201526a10b1b7b73a3937b63632b960a91b604482015290519081900360640190fd5b6123eb82612e66565b50600054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561243757600080fd5b505afa15801561244b573d6000803e3d6000fd5b505050506040513d602081101561246157600080fd5b5051600754600080546040805163368da5ef60e11b81526001600160a01b03928316600482015290519495509193921691636d1b4bde91602480820192602092909190829003018186803b1580156124b857600080fd5b505afa1580156124cc573d6000803e3d6000fd5b505050506040513d60208110156124e257600080fd5b505190506001600160a01b03811661252a576040805162461bcd60e51b815260206004820152600660248201526521676c6f626560d01b604482015290519081900360640190fd5b600054612547906001600160a01b0316828463ffffffff61317416565b50919050565b6009546001600160a01b03163314612598576040805162461bcd60e51b81526020600482015260096024820152682174696d656c6f636b60b81b604482015290519081900360640190fd5b600355565b6006546001600160a01b031633146125ea576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b600880546001600160a01b0319166001600160a01b0392909216919091179055565b60008054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561265857600080fd5b505afa15801561266c573d6000803e3d6000fd5b505050506040513d602081101561268257600080fd5b5051905080156127a357600080546126bb916001600160a01b0390911690600080516020613ce68339815191529063ffffffff6137b116565b6000546126e6906001600160a01b0316600080516020613ce68339815191528363ffffffff6137b116565b600080516020613ce68339815191526001600160a01b031663a0712d68826040518263ffffffff1660e01b815260040180828152602001915050602060405180830381600087803b15801561273a57600080fd5b505af115801561274e573d6000803e3d6000fd5b505050506040513d602081101561276457600080fd5b5051156127a3576040805162461bcd60e51b81526020600482015260086024820152670859195c1bdcda5d60c21b604482015290519081900360640190fd5b50565b6009546001600160a01b031681565b336000908152600f602052604090205460ff16806127d257503330145b806127e757506008546001600160a01b031633145b806127fc57506006546001600160a01b031633145b612838576040805162461bcd60e51b8152602060048201526008602482015267216b65657065727360c01b604482015290519081900360640190fd5b60006128426120da565b9050600061284e611ae1565b90508183101580156128605750808311155b61289f576040805162461bcd60e51b815260206004820152600b60248201526a2164656c6576657261676560a81b604482015290519081900360640190fd5b60006128a9611449565b905060006128b5611f59565b90505b846128c9848363ffffffff612dcb16565b10156128e2576128df838663ffffffff612dcb16565b90505b600080516020613ce68339815191526001600160a01b031663852a12e3826040518263ffffffff1660e01b815260040180828152602001915050602060405180830381600087803b15801561293657600080fd5b505af115801561294a573d6000803e3d6000fd5b505050506040513d602081101561296057600080fd5b50511561299e576040805162461bcd60e51b81526020600482015260076024820152662172656465656d60c81b604482015290519081900360640190fd5b6129d273d586e7f844cea2f87f50152665bcbc2c279d8d70600080516020613ce6833981519152600063ffffffff6137b116565b612a0573d586e7f844cea2f87f50152665bcbc2c279d8d70600080516020613ce68339815191528363ffffffff6137b116565b600080516020613ce68339815191526001600160a01b0316630e752702826040518263ffffffff1660e01b815260040180828152602001915050602060405180830381600087803b158015612a5957600080fd5b505af1158015612a6d573d6000803e3d6000fd5b505050506040513d6020811015612a8357600080fd5b505115612ac0576040805162461bcd60e51b815260206004820152600660248201526521726570617960d01b604482015290519081900360640190fd5b612ad0838263ffffffff612dcb16565b9250612aee82610fcf83670de0b6b3a764000063ffffffff612e0d16565b90508483116128b8575050505050565b336000908152600f602052604090205460ff1680612b1b57503330145b80612b3057506008546001600160a01b031633145b80612b4557506006546001600160a01b031633145b612b81576040805162461bcd60e51b8152602060048201526008602482015267216b65657065727360c01b604482015290519081900360640190fd5b6000612b8b610c76565b90506000612b976120da565b9050808310158015612bc45750612bc0670de0b6b3a7640000610fcf838563ffffffff612e0d16565b8311155b612c01576040805162461bcd60e51b8152602060048201526009602482015268216c6576657261676560b81b604482015290519081900360640190fd5b600080612c0c611ae1565b90505b8481101561130157612c1f6120f1565b915084612c32828463ffffffff61311a16565b1115612c4b57612c48858263ffffffff612dcb16565b91505b600080516020613ce68339815191526001600160a01b031663c5ebeaec836040518263ffffffff1660e01b815260040180828152602001915050602060405180830381600087803b158015612c9f57600080fd5b505af1158015612cb3573d6000803e3d6000fd5b505050506040513d6020811015612cc957600080fd5b50612cd4905061260c565b612ce4818363ffffffff61311a16565b9050612c0f565b73d586e7f844cea2f87f50152665bcbc2c279d8d7081565b6000612d0d6120da565b90506127a3816127b5565b6007546001600160a01b031681565b600080612d32610f9a565b90506000612d3e611c1b565b905080821115612d77576000612d526120da565b90506000612d5f826121c4565b9050612d6a816127b5565b6001945050505050610cb4565b60009250505090565b6000612dc283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506138c4565b90505b92915050565b6000612dc283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250613966565b600082612e1c57506000612dc5565b82820282848281612e2957fe5b0414612dc25760405162461bcd60e51b8152600401808060200182810382526021815260200180613cc56021913960400191505060405180910390fd5b600080612e71612346565b905082811015613113576000612e8d848363ffffffff612dcb16565b905080600080516020613ce68339815191526001600160a01b0316633b1d21a26040518163ffffffff1660e01b815260040160206040518083038186803b158015612ed757600080fd5b505afa158015612eeb573d6000803e3d6000fd5b505050506040513d6020811015612f0157600080fd5b50511015612f48576040805162461bcd60e51b815260206004820152600f60248201526e21636173682d6c697175696469747960881b604482015290519081900360640190fd5b6000612f52611d02565b90506000612f5e611ae1565b90506000612f6a611a9d565b90506000612f8a670de0b6b3a7640000610fcf878563ffffffff612e0d16565b905083811115612fec57306001600160a01b031663f53f13506040518163ffffffff1660e01b8152600401600060405180830381600087803b158015612fcf57600080fd5b505af1158015612fe3573d6000803e3d6000fd5b50505050613051565b3063eb514af9613002858463ffffffff612dcb16565b6040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b15801561303857600080fd5b505af115801561304c573d6000803e3d6000fd5b505050505b600080516020613ce68339815191526001600160a01b031663852a12e3866040518263ffffffff1660e01b815260040180828152602001915050602060405180830381600087803b1580156130a557600080fd5b505af11580156130b9573d6000803e3d6000fd5b505050506040513d60208110156130cf57600080fd5b50511561310d576040805162461bcd60e51b81526020600482015260076024820152662172656465656d60c81b604482015290519081900360640190fd5b50505050505b5090919050565b600082820183811015612dc2576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b1790526131c69084906139c0565b505050565b6001600160a01b0382166131de57600080fd5b6001546131ff906001600160a01b038581169116600063ffffffff6137b116565b60015461321f906001600160a01b0385811691168363ffffffff6137b116565b60606001600160a01b0384167360781c2586d68229fde47564546784ab3faca982148061326857506001600160a01b0383167360781c2586d68229fde47564546784ab3faca982145b1561330057600260005b5060405190808252806020026020018201604052801561329c578160200160208202803683370190505b50905083816000815181106132ad57fe5b60200260200101906001600160a01b031690816001600160a01b03168152505082816001815181106132db57fe5b60200260200101906001600160a01b031690816001600160a01b031681525050613415565b6001600160a01b03841673b31f66aa3c1e785363f0875a1b74e27b85fd66c7148061334757506001600160a01b03831673b31f66aa3c1e785363f0875a1b74e27b85fd66c7145b156133555760026000613272565b604080516003808252608082019092529060208201606080368337019050509050838160008151811061338457fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507360781c2586d68229fde47564546784ab3faca982816001815181106133c657fe5b60200260200101906001600160a01b031690816001600160a01b03168152505082816002815181106133f457fe5b60200260200101906001600160a01b031690816001600160a01b0316815250505b6001546001600160a01b03166338ed1739836000843061343c42603c63ffffffff61311a16565b6040518663ffffffff1660e01b81526004018086815260200185815260200180602001846001600160a01b03166001600160a01b03168152602001838152602001828103825285818151815260200191508051906020019060200280838360005b838110156134b557818101518382015260200161349d565b505050509050019650505050505050600060405180830381600087803b1580156134de57600080fd5b505af11580156134f2573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052602081101561351b57600080fd5b810190808051604051939291908464010000000082111561353b57600080fd5b90830190602082018581111561355057600080fd5b825186602082028301116401000000008211171561356d57600080fd5b82525081516020918201928201910280838360005b8381101561359a578181015183820152602001613582565b505050509050016040525050505050505050565b60008054604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b1580156135fa57600080fd5b505afa15801561360e573d6000803e3d6000fd5b505050506040513d602081101561362457600080fd5b5051905080156127a357600754604080516361d027b360e01b815290516136bc926001600160a01b0316916361d027b3916004808301926020929190829003018186803b15801561367457600080fd5b505afa158015613688573d6000803e3d6000fd5b505050506040513d602081101561369e57600080fd5b50516002546112e89061271090610fcf90869063ffffffff612e0d16565b60075460408051638d8f1e6760e01b8152905161374a926001600160a01b031691638d8f1e67916004808301926020929190829003018186803b15801561370257600080fd5b505afa158015613716573d6000803e3d6000fd5b505050506040513d602081101561372c57600080fd5b50516003546112e89061271090610fcf90869063ffffffff612e0d16565b6127a361260c565b600080600061375f613cb1565b6137698686613a71565b9092509050600082600381111561377c57fe5b1461378d575091506000905061379f565b600061379882613ad9565b9350935050505b9250929050565b6127a36110bd610cb7565b801580613837575060408051636eb1769f60e11b81523060048201526001600160a01b03848116602483015291519185169163dd62ed3e91604480820192602092909190829003018186803b15801561380957600080fd5b505afa15801561381d573d6000803e3d6000fd5b505050506040513d602081101561383357600080fd5b5051155b6138725760405162461bcd60e51b8152600401808060200182810382526036815260200180613d306036913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b1790526131c69084906139c0565b600081836139505760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156139155781810151838201526020016138fd565b50505050905090810190601f1680156139425780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50600083858161395c57fe5b0495945050505050565b600081848411156139b85760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156139155781810151838201526020016138fd565b505050900390565b6060613a15826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316613ae89092919063ffffffff16565b8051909150156131c657808060200190516020811015613a3457600080fd5b50516131c65760405162461bcd60e51b815260040180806020018281038252602a815260200180613d06602a913960400191505060405180910390fd5b6000613a7b613cb1565b600080613a8c866000015186613aff565b90925090506000826003811115613a9f57fe5b14613abe5750604080516020810190915260008152909250905061379f565b60408051602081019091529081526000969095509350505050565b51670de0b6b3a7640000900490565b6060613af78484600085613b3e565b949350505050565b60008083613b125750600090508061379f565b83830283858281613b1f57fe5b0414613b335750600291506000905061379f565b60009250905061379f565b6060613b4985613cab565b613b9a576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b60208310613bd95780518252601f199092019160209182019101613bba565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114613c3b576040519150601f19603f3d011682016040523d82523d6000602084013e613c40565b606091505b50915091508115613c54579150613af79050565b805115613c645780518082602001fd5b60405162461bcd60e51b81526020600482018181528651602484015286518793919283926044019190850190808383600083156139155781810151838201526020016138fd565b3b151590565b604051806020016040528060008152509056fe536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77000000000000000000000000835866d37afb8cb8f8334dccdaf66cf01832ff5d5361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a2646970667358221220a899cd43a52c66b9b94288fdcb322bf1821f4496e65fcd502bb5a1cc64b20be164736f6c63430006070033000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a000000000000000000000000c9a51fb9057380494262fd291aed74317332c0a2000000000000000000000000f7b8d9f8a82a7a6dd448398afc5c77744bd6cb85000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a000000000000000000000000c9a51fb9057380494262fd291aed74317332c0a2000000000000000000000000f7b8d9f8a82a7a6dd448398afc5c77744bd6cb85000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a
-----Decoded View---------------
Arg [0] : _governance (address): 0x294ab3200ef36200db84c4128b7f1b4eec71e38a
Arg [1] : _strategist (address): 0xc9a51fb9057380494262fd291aed74317332c0a2
Arg [2] : _controller (address): 0xf7b8d9f8a82a7a6dd448398afc5c77744bd6cb85
Arg [3] : _timelock (address): 0x294ab3200ef36200db84c4128b7f1b4eec71e38a
-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a
Arg [1] : 000000000000000000000000c9a51fb9057380494262fd291aed74317332c0a2
Arg [2] : 000000000000000000000000f7b8d9f8a82a7a6dd448398afc5c77744bd6cb85
Arg [3] : 000000000000000000000000294ab3200ef36200db84c4128b7f1b4eec71e38a
Deployed ByteCode Sourcemap
76795:13575:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12:1:-1;9;2:12;80777:276:0;;5:9:-1;2:2;;;27:1;24;17:12;2:2;80777:276:0;;;:::i;:::-;;;;;;;;;;;;;;;;79257:206;;5:9:-1;2:2;;;27:1;24;17:12;2:2;79257:206:0;;;:::i;56881:74::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;56881:74:0;;;:::i;:::-;;;;-1:-1:-1;;;;;56881:74:0;;;;;;;;;;;;;;83436:213;;5:9:-1;2:2;;;27:1;24;17:12;2:2;83436:213:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;83436:213:0;-1:-1:-1;;;;;83436:213:0;;:::i;:::-;;78651:110;;5:9:-1;2:2;;;27:1;24;17:12;2:2;78651:110:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;78651:110:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;77071:74;;5:9:-1;2:2;;;27:1;24;17:12;2:2;77071:74:0;;;:::i;59376:207::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;59376:207:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;59376:207:0;-1:-1:-1;;;;;59376:207:0;;:::i;63871:1053::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;63871:1053:0;;;;;;;;;;;;;;;27:11:-1;11:28;;8:2;;;52:1;49;42:12;8:2;63871:1053:0;;41:9:-1;34:4;18:14;14:25;11:40;8:2;;;64:1;61;54:12;8:2;63871:1053:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;63871:1053:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;63871:1053:0;;-1:-1:-1;63871:1053:0;;-1:-1:-1;;;;;63871:1053:0:i;56855:19::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;56855:19:0;;;:::i;57790:25::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57790:25:0;;;:::i;60180:213::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;60180:213:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;60180:213:0;;:::i;57246:54::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57246:54:0;;;:::i;81466:195::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;81466:195:0;;;:::i;61558:1032::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;61558:1032:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;61558:1032:0;;:::i;83657:284::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;83657:284:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;83657:284:0;;:::i;79843:347::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;79843:347:0;;;:::i;83219:209::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;83219:209:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;83219:209:0;-1:-1:-1;;;;;83219:209:0;;:::i;77165:74::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;77165:74:0;;;:::i;80541:172::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;80541:172:0;;;:::i;87878:885::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;87878:885:0;;;:::i;57642:53::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57642:53:0;;;:::i;61191:289::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;61191:289:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;61191:289:0;-1:-1:-1;;;;;61191:289:0;;:::i;57596:39::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57596:39:0;;;:::i;59159:209::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;59159:209:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;59159:209:0;-1:-1:-1;;;;;59159:209:0;;:::i;57195:44::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57195:44:0;;;:::i;83949:254::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;83949:254:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;83949:254:0;;:::i;57726:25::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57726:25:0;;;:::i;57055:74::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57055:74:0;;;:::i;82965:215::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;82965:215:0;;;:::i;81872:124::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;81872:124:0;;;:::i;79116:133::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;79116:133:0;;;:::i;56962:72::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;56962:72:0;;;:::i;76857:80::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;76857:80:0;;;:::i;58934:113::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;58934:113:0;;;:::i;80198:335::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;80198:335:0;;;:::i;78769:339::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;78769:339:0;;;:::i;82004:125::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;82004:125:0;;;:::i;59790:195::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;59790:195:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;59790:195:0;;:::i;63168:440::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;63168:440:0;;;:::i;82553:404::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;82553:404:0;;;:::i;57854:42::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57854:42:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;57854:42:0;-1:-1:-1;;;;;57854:42:0;;:::i;:::-;;;;;;;;;;;;;;;;;;57309:36;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57309:36:0;;;:::i;57486:40::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57486:40:0;;;:::i;60878:151::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;60878:151:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;60878:151:0;-1:-1:-1;;;;;60878:151:0;;:::i;81669:195::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;81669:195:0;;;:::i;82137:408::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;82137:408:0;;;:::i;79607:228::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;79607:228:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;79607:228:0;;:::i;60564:155::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;60564:155:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;60564:155:0;-1:-1:-1;;;;;60564:155:0;;:::i;59591:191::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;59591:191:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;59591:191:0;;:::i;84863:216::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;84863:216:0;;;:::i;60727:143::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;60727:143:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;60727:143:0;-1:-1:-1;;;;;60727:143:0;;:::i;58737:118::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;58737:118:0;;;:::i;62654:438::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;62654:438:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;62654:438:0;;:::i;59993:179::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;59993:179:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;59993:179:0;;:::i;60401:155::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;60401:155:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;60401:155:0;-1:-1:-1;;;;;60401:155:0;;:::i;88772:314::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;88772:314:0;;;:::i;57822:23::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57822:23:0;;;:::i;86444:1368::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;86444:1368:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;86444:1368:0;;:::i;85189:985::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;85189:985:0;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;85189:985:0;;:::i;76974:72::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;76974:72:0;;;:::i;86182:150::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;86182:150:0;;;:::i;57758:25::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;57758:25:0;;;:::i;84369:486::-;;5:9:-1;2:2;;;27:1;24;17:12;2:2;84369:486:0;;;:::i;80777:276::-;80824:7;80844:29;80876:26;:24;:26::i;:::-;80844:58;-1:-1:-1;80953:16:0;80972:47;80980:4;80990;:28;;;80972:47;:17;:47;:::i;:::-;80953:66;-1:-1:-1;;;80777:276:0;;:::o;79257:206::-;79312:7;79332:16;79351:17;:15;:17::i;:::-;79332:36;;79379:16;79398:17;:15;:17::i;:::-;79379:36;-1:-1:-1;79433:22:0;:8;79379:36;79433:22;:12;:22;:::i;56881:74::-;56913:42;56881:74;:::o;83436:213::-;83529:10;;-1:-1:-1;;;;;83529:10:0;83515;:24;;:52;;-1:-1:-1;83557:10:0;;-1:-1:-1;;;;;83557:10:0;83543;:24;83515:52;83493:113;;;;;-1:-1:-1;;;83493:113:0;;;;;;;;;;;;-1:-1:-1;;;83493:113:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;83617:16:0;83636:5;83617:16;;;:7;:16;;;;;:24;;-1:-1:-1;;83617:24:0;;;83436:213::o;78651:110::-;78728:25;;;;;;;;;;;;-1:-1:-1;;;78728:25:0;;;;78651:110;:::o;77071:74::-;77103:42;77071:74;:::o;59376:207::-;59463:10;;-1:-1:-1;;;;;59463:10:0;59449;:24;;:66;;-1:-1:-1;59505:10:0;;-1:-1:-1;;;;;59505:10:0;59491;:24;59449:66;59441:93;;;;;-1:-1:-1;;;59441:93:0;;;;;;;;;;;;-1:-1:-1;;;59441:93:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;59545:22:0;59570:5;59545:22;;;:10;:22;;;;;:30;;-1:-1:-1;;59545:30:0;;;59376:207::o;63871:1053::-;64037:8;;63976:21;;-1:-1:-1;;;;;64037:8:0;64023:10;:22;64015:44;;;;;-1:-1:-1;;;64015:44:0;;;;;;;;;;;;-1:-1:-1;;;64015:44:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;64078:21:0;;64070:41;;;;;-1:-1:-1;;;64070:41:0;;;;;;;;;;;;-1:-1:-1;;;64070:41:0;;;;;;;;;;;;;;;64388:1;64368;64343:5;64337:12;64313:4;64306:5;64302:16;64276:7;64252:4;64245:5;64241:16;64210:194;64430:16;64480:4;64474:11;64462:23;;64597:4;64593:9;64586:4;64579;64573;64569:15;64565:26;64561:42;64551:8;64547:57;64524:4;64499:120;64650:4;64640:8;64633:22;64708:4;64705:1;64698:4;64688:8;64684:19;64669:44;64743:9;64736:17;64776:1;64771:135;;;;64729:177;;64771:135;64882:4;64875;64865:8;64861:19;64854:33;64729:177;;;;64178:739;;;;:::o;56855:19::-;;;-1:-1:-1;;;;;56855:19:0;;:::o;57790:25::-;;;-1:-1:-1;;;;;57790:25:0;;:::o;60180:213::-;60304:8;;-1:-1:-1;;;;;60304:8:0;60290:10;:22;60282:44;;;;;-1:-1:-1;;;60282:44:0;;;;;;;;;;;;-1:-1:-1;;;60282:44:0;;;;;;;;;;;;;;;60337:22;:48;60180:213::o;57246:54::-;57295:5;57246:54;:::o;81466:195::-;81506:7;81526:16;81545:13;:11;:13::i;:::-;81526:32;;81569:16;81588:13;:11;:13::i;:::-;81569:32;-1:-1:-1;81621:32:0;81644:8;81621:18;81569:32;81634:4;81621:18;:12;:18;:::i;:::-;:22;:32;:22;:32;:::i;61558:1032::-;61635:10;;-1:-1:-1;;;;;61635:10:0;61621;:24;61613:48;;;;;-1:-1:-1;;;61613:48:0;;;;;;;;;;;;-1:-1:-1;;;61613:48:0;;;;;;;;;;;;;;;61672:16;61698:4;;61691:37;;;-1:-1:-1;;;61691:37:0;;61722:4;61691:37;;;;;;-1:-1:-1;;;;;61698:4:0;;;;61691:22;;:37;;;;;;;;;;;;;;;61698:4;61691:37;;;2:2:-1;;;;27:1;24;17:12;2:2;61691:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;61691:37:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;61691:37:0;;-1:-1:-1;61743:18:0;;;61739:143;;;61788:36;61802:21;:7;61814:8;61802:21;:11;:21;:::i;:::-;61788:13;:36::i;:::-;61778:46;-1:-1:-1;61849:21:0;61778:46;61861:8;61849:21;:11;:21;:::i;:::-;61839:31;;61739:143;61894:15;61912:83;57689:6;61912:33;61924:20;;61912:7;:11;;:33;;;;:::i;:83::-;61894:101;;62006:69;62044:10;;;;;;;;;-1:-1:-1;;;;;62044:10:0;-1:-1:-1;;;;;62032:31:0;;:33;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;62032:33:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;62032:33:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;62032:33:0;62013:4;;-1:-1:-1;;;;;62013:4:0;;62067:7;62006:69;:25;:69;:::i;:::-;62088:20;62111:85;57581:6;62111:34;62123:21;;62111:7;:11;;:34;;;;:::i;:85::-;62088:108;;62207:112;62259:10;;;;;;;;;-1:-1:-1;;;;;62259:10:0;-1:-1:-1;;;;;62247:32:0;;:34;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;62207:112:0;62361:10;;62332:14;62388:4;;62349:45;;;-1:-1:-1;;;62349:45:0;;-1:-1:-1;;;;;62388:4:0;;;62349:45;;;;;;62332:14;;62361:10;;;;;62349:30;;:45;;;;;;;;;;;;;;;62361:10;62349:45;;;2:2:-1;;;;27:1;24;17:12;2:2;62349:45:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;62349:45:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;62349:45:0;;-1:-1:-1;;;;;;62413:20:0;;62405:39;;;;;-1:-1:-1;;;62405:39:0;;;;;;;;;;;;-1:-1:-1;;;62405:39:0;;;;;;;;;;;;;;;62509:73;62535:6;62543:38;62568:12;62543:20;:7;62555;62543:20;:11;:20;:::i;:::-;:24;:38;:24;:38;:::i;:::-;62516:4;;-1:-1:-1;;;;;62516:4:0;;62509:73;;:25;:73;:::i;:::-;61558:1032;;;;;:::o;83657:284::-;83795:10;;-1:-1:-1;;;;;83795:10:0;83781;:24;;:52;;-1:-1:-1;83823:10:0;;-1:-1:-1;;;;;83823:10:0;83809;:24;83781:52;83759:113;;;;;-1:-1:-1;;;83759:113:0;;;;;;;;;;;;-1:-1:-1;;;83759:113:0;;;;;;;;;;;;;;;83883:23;:50;83657:284::o;79843:347::-;79900:7;79920:17;79940:20;:18;:20::i;:::-;79920:40;;80021:21;80045:104;80073:65;80111:26;;80073:33;80101:4;80073:23;;:27;;:33;;;;:::i;:65::-;80045:9;;:104;:13;:104;:::i;83219:209::-;83309:10;;-1:-1:-1;;;;;83309:10:0;83295;:24;;:52;;-1:-1:-1;83337:10:0;;-1:-1:-1;;;;;83337:10:0;83323;:24;83295:52;83273:113;;;;;-1:-1:-1;;;83273:113:0;;;;;;;;;;;;-1:-1:-1;;;83273:113:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;83397:16:0;;;;;:7;:16;;;;;:23;;-1:-1:-1;;83397:23:0;83416:4;83397:23;;;83219:209::o;77165:74::-;-1:-1:-1;;;;;;;;;;;77165:74:0;:::o;80541:172::-;80636:40;;;-1:-1:-1;;;80636:40:0;;-1:-1:-1;;;;;;;;;;;80636:40:0;;;;;;80592:7;;;;76895:42;;80636:33;;:40;;;;;;;;;;;;;76895:42;80636:40;;;2:2:-1;;;;27:1;24;17:12;2:2;80636:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;80636:40:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;80636:40:0;;;;-1:-1:-1;;80541:172:0;:::o;87878:885::-;58568:10;58557:22;;;;:10;:22;;;;;;;;;:67;;-1:-1:-1;58614:10:0;;-1:-1:-1;;;;;58614:10:0;58600;:24;58557:67;:112;;;-1:-1:-1;58659:10:0;;-1:-1:-1;;;;;58659:10:0;58645;:24;58557:112;58535:145;;12:1:-1;9;2:12;58535:145:0;87967:16:::1;::::0;;87981:1:::1;87967:16:::0;;;;;::::1;::::0;;;87939:25:::1;::::0;87967:16:::1;::::0;;::::1;::::0;;109:14:-1::1;87967:16:0::0;88:42:-1::1;144:17;::::0;-1:-1;87967:16:0::1;87939:44;;-1:-1:-1::0;;;;;;;;;;;87994:8:0::1;88003:1;87994:11;;;;;;;;-1:-1:-1::0;;;;;87994:19:0;;::::1;:11;::::0;;::::1;::::0;;;;;;;:19;88026:55:::1;::::0;;-1:-1:-1;;;88026:55:0;;88064:1:::1;88026:55;::::0;::::1;::::0;;;88075:4:::1;88026:55:::0;;;;;;76895:42:::1;::::0;88026:37:::1;::::0;:55;;;;;;;;;;;88064:1;76895:42;88026:55;::::1;;2:2:-1::0;::::1;;;27:1;24::::0;17:12:::1;2:2;88026:55:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;-1:-1:::0;;88119:38:0::1;::::0;;-1:-1:-1;;;88119:38:0;;88151:4:::1;88119:38;::::0;::::1;::::0;;;88102:14:::1;::::0;-1:-1:-1;77103:42:0::1;::::0;-1:-1:-1;88119:23:0::1;::::0;:38;;;;;::::1;::::0;;;;;;;;;77103:42;88119:38;::::1;;2:2:-1::0;::::1;;;27:1;24::::0;17:12:::1;2:2;88119:38:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;88119:38:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28::::0;21:12:::1;4:2;-1:-1:::0;88119:38:0;;-1:-1:-1;88172:10:0;;88168:77:::1;;88220:4;::::0;88199:34:::1;::::0;77103:42:::1;::::0;-1:-1:-1;;;;;88220:4:0::1;88226:6:::0;88199:13:::1;:34::i;:::-;88255:55;::::0;;-1:-1:-1;;;88255:55:0;;88293:1:::1;88255:55;::::0;::::1;::::0;88304:4:::1;88255:55:::0;;;;;;76895:42:::1;::::0;88255:37:::1;::::0;:55;;;;;-1:-1:-1;;88255:55:0;;;;;;;-1:-1:-1;76895:42:0;88255:55;::::1;;2:2:-1::0;::::1;;;27:1;24::::0;17:12:::1;2:2;88255:55:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;-1:-1:::0;88343:21:0::1;::::0;-1:-1:-1;;88419:9:0;;;-1:-1:-1;88415:133:0::1;;56913:42;-1:-1:-1::0;;;;;88500:20:0::1;;88528:5;88500:36;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24::::0;17:12:::1;2:2;88500:36:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;88500:36:0;;;;;88415:133;88579:38;::::0;;-1:-1:-1;;;88579:38:0;;88611:4:::1;88579:38;::::0;::::1;::::0;;;88562:14:::1;::::0;56913:42:::1;::::0;88579:23:::1;::::0;:38;;;;;::::1;::::0;;;;;;;;;56913:42;88579:38;::::1;;2:2:-1::0;::::1;;;27:1;24::::0;17:12:::1;2:2;88579:38:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;88579:38:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28::::0;21:12:::1;4:2;-1:-1:::0;88579:38:0;;-1:-1:-1;88632:10:0;;88628:77:::1;;88680:4;::::0;88659:34:::1;::::0;56913:42:::1;::::0;-1:-1:-1;;;;;88680:4:0::1;88686:6:::0;88659:13:::1;:34::i;:::-;88717:38;:36;:38::i;:::-;58691:1;;;;87878:885::o:0;57642:53::-;57689:6;57642:53;:::o;61191:289::-;61292:10;;61242:15;;-1:-1:-1;;;;;61292:10:0;61278;:24;61270:48;;;;;-1:-1:-1;;;61270:48:0;;;;;;;;;;;;-1:-1:-1;;;61270:48:0;;;;;;;;;;;;;;;61337:4;;-1:-1:-1;;;;;61337:23:0;;;:4;;:23;;61329:40;;;;;-1:-1:-1;;;61329:40:0;;;;;;;;;;;;;;;-1:-1:-1;;;61329:40:0;;;;;;;;;;;;;;;61390:31;;;-1:-1:-1;;;61390:31:0;;61415:4;61390:31;;;;;;-1:-1:-1;;;;;61390:16:0;;;;;:31;;;;;;;;;;;;;;:16;:31;;;2:2:-1;;;;27:1;24;17:12;2:2;61390:31:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;61390:31:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;61390:31:0;61452:10;;61390:31;;-1:-1:-1;61432:40:0;;-1:-1:-1;;;;;61432:19:0;;;;61452:10;61390:31;61432:40;:19;:40;:::i;:::-;61191:289;;;:::o;57596:39::-;;;;:::o;59159:209::-;59249:10;;-1:-1:-1;;;;;59249:10:0;59235;:24;;:66;;-1:-1:-1;59291:10:0;;-1:-1:-1;;;;;59291:10:0;59277;:24;59235:66;59227:93;;;;;-1:-1:-1;;;59227:93:0;;;;;;;;;;;;-1:-1:-1;;;59227:93:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;59331:22:0;;;;;:10;:22;;;;;:29;;-1:-1:-1;;59331:29:0;59356:4;59331:29;;;59159:209::o;57195:44::-;;;;:::o;83949:254::-;84065:10;;-1:-1:-1;;;;;84065:10:0;84051;:24;;:52;;-1:-1:-1;84093:10:0;;-1:-1:-1;;;;;84093:10:0;84079;:24;84051:52;84029:113;;;;;-1:-1:-1;;;84029:113:0;;;;;;;;;;;;-1:-1:-1;;;84029:113:0;;;;;;;;;;;;;;;84153:19;:42;83949:254::o;57726:25::-;;;-1:-1:-1;;;;;57726:25:0;;:::o;57055:74::-;;;-1:-1:-1;;;;;57055:74:0;;:::o;82965:215::-;83011:7;83031:16;83050:13;:11;:13::i;:::-;83031:32;;83074:16;83093:13;:11;:13::i;:::-;83074:32;-1:-1:-1;83126:46:0;83149:22;:8;83074:32;83149:22;:12;:22;:::i;:::-;83126:18;:8;83139:4;83126:18;:12;:18;:::i;81872:124::-;81938:50;;;-1:-1:-1;;;81938:50:0;;81982:4;81938:50;;;;;;81911:7;;-1:-1:-1;;;;;;;;;;;77197:42:0;81938:35;;:50;;;;;;;;;;;;;;;81911:7;77197:42;81938:50;;;2:2:-1;;;;27:1;24;17:12;2:2;81938:50:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;81938:50:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;81938:50:0;;-1:-1:-1;81872:124:0;:::o;79116:133::-;79191:50;;;-1:-1:-1;;;79191:50:0;;79235:4;79191:50;;;;;;79164:7;;-1:-1:-1;;;;;;;;;;;77197:42:0;79191:35;;:50;;;;;;;;;;;;;;;77197:42;79191:50;;;2:2:-1;;;;27:1;24;17:12;2:2;79191:50:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;56962:72:0;56992:42;56962:72;:::o;76857:80::-;76895:42;76857:80;:::o;58934:113::-;58976:7;59003:36;59023:15;:13;:15::i;:::-;59003;:13;:15::i;:::-;:19;:36;:19;:36;:::i;:::-;58996:43;;58934:113;:::o;80198:335::-;80251:7;80271:17;80291:20;:18;:20::i;:::-;80271:40;;80372:21;80396:96;80424:57;80458:22;;80424:29;80448:4;80424:19;;:23;;:29;;;;:::i;78769:339::-;78886:63;;;-1:-1:-1;;;78886:63:0;;78943:4;78886:63;;;;;;78817:7;;;;;;-1:-1:-1;;;;;;;;;;;77197:42:0;78886:48;;:63;;;;;;;;;;;;;;;77197:42;78886:63;;;2:2:-1;;;;27:1;24;17:12;2:2;78886:63:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;78886:63:0;;;;;;;15:3:-1;10;7:12;4:2;;;32:1;29;22:12;4:2;-1:-1;78886:63:0;;;;;;;;;;;79012:29;;;;;;;;;;78886:63;;-1:-1:-1;78886:63:0;;-1:-1:-1;78965:11:0;;78980:97;;78886:63;78980:17;:97::i;:::-;78962:115;-1:-1:-1;;;;;78769:339:0;:::o;82004:125::-;82070:51;;;-1:-1:-1;;;82070:51:0;;82115:4;82070:51;;;;;;82043:7;;-1:-1:-1;;;;;;;;;;;77197:42:0;82070:36;;:51;;;;;;;;;;;;;;;82043:7;77197:42;82070:51;;;2:2:-1;;;;27:1;24;17:12;59790:195:0;59898:8;;-1:-1:-1;;;;;59898:8:0;59884:10;:22;59876:44;;;;;-1:-1:-1;;;59876:44:0;;;;;;;;;;;;-1:-1:-1;;;59876:44:0;;;;;;;;;;;;;;;59931:21;:46;59790:195::o;63168:440::-;63259:10;;63209:15;;-1:-1:-1;;;;;63259:10:0;63245;:24;63237:48;;;;;-1:-1:-1;;;63237:48:0;;;;;;;;;;;;-1:-1:-1;;;63237:48:0;;;;;;;;;;;;;;;63296:14;:12;:14::i;:::-;63340:4;;63333:37;;;-1:-1:-1;;;63333:37:0;;63364:4;63333:37;;;;;;-1:-1:-1;;;;;63340:4:0;;;;63333:22;;:37;;;;;;;;;;;;;;;63340:4;63333:37;;;2:2:-1;;;;27:1;24;17:12;2:2;63333:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;63333:37:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;63333:37:0;63412:10;;63383:14;63439:4;;63400:45;;;-1:-1:-1;;;63400:45:0;;-1:-1:-1;;;;;63439:4:0;;;63400:45;;;;;;63333:37;;-1:-1:-1;63383:14:0;;63412:10;;;63400:30;;:45;;;;;63333:37;;63400:45;;;;;;;;63412:10;63400:45;;;2:2:-1;;;;27:1;24;17:12;2:2;63400:45:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;63400:45:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;63400:45:0;;-1:-1:-1;;;;;;63464:20:0;;63456:39;;;;;-1:-1:-1;;;63456:39:0;;;;;;;;;;;;-1:-1:-1;;;63456:39:0;;;;;;;;;;;;;;;63565:4;;63558:42;;-1:-1:-1;;;;;63565:4:0;63584:6;63592:7;63558:42;:25;:42;:::i;:::-;63168:440;;:::o;82553:404::-;82594:7;82614:16;82633:13;:11;:13::i;:::-;82614:32;;82657:16;82676:13;:11;:13::i;:::-;82726:40;;;-1:-1:-1;;;82726:40:0;;-1:-1:-1;;;;;;;;;;;82726:40:0;;;;;;82657:32;;-1:-1:-1;82705:17:0;;76895:42;;82726:33;;:40;;;;;;;;;;;76895:42;82726:40;;;2:2:-1;;;;27:1;24;17:12;2:2;82726:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;82726:40:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;82726:40:0;;;;-1:-1:-1;82849:100:0;82929:5;82849:57;82901:4;82849:47;82862:33;82726:40;82849:57;82862:8;82875:4;82862:18;:12;:18;:::i;:33::-;82849:8;;:47;:12;:47;:::i;:::-;:51;:57;:51;:57;:::i;:100::-;82829:120;;;;;82553:404;:::o;57854:42::-;;;;;;;;;;;;;;;:::o;57309:36::-;;;;:::o;57486:40::-;;;;:::o;60878:151::-;60964:8;;-1:-1:-1;;;;;60964:8:0;60950:10;:22;60942:44;;;;;-1:-1:-1;;;60942:44:0;;;;;;;;;;;;-1:-1:-1;;;60942:44:0;;;;;;;;;;;;;;;60997:10;:24;;-1:-1:-1;;;;;;60997:24:0;-1:-1:-1;;;;;60997:24:0;;;;;;;;;;60878:151::o;81669:195::-;81719:7;81739:16;81758:13;:11;:13::i;:::-;81739:32;;81782:16;81801:13;:11;:13::i;82137:408::-;82178:7;82198:16;82217:13;:11;:13::i;:::-;82198:32;;82241:16;82260:13;:11;:13::i;:::-;82310:40;;;-1:-1:-1;;;82310:40:0;;-1:-1:-1;;;;;;;;;;;82310:40:0;;;;;;82241:32;;-1:-1:-1;82289:17:0;;76895:42;;82310:33;;:40;;;;;;;;;;;76895:42;82310:40;;;2:2:-1;;;;27:1;24;17:12;2:2;82310:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;82310:40:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;82310:40:0;;;;-1:-1:-1;82437:100:0;82517:5;82437:57;82489:4;82437:47;82475:8;82437:33;82465:4;82437:57;:8;82310:40;82437:23;:12;:23;:::i;79607:228::-;79712:7;79737:16;79756;:14;:16::i;:::-;79737:35;-1:-1:-1;79790:37:0;79822:4;79790:27;:13;79737:35;79790:27;:17;:27;:::i;:37::-;79783:44;79607:228;-1:-1:-1;;;79607:228:0:o;60564:155::-;60650:10;;-1:-1:-1;;;;;60650:10:0;60636;:24;60628:48;;;;;-1:-1:-1;;;60628:48:0;;;;;;;;;;;;-1:-1:-1;;;60628:48:0;;;;;;;;;;;;;;;60687:10;:24;;-1:-1:-1;;;;;;60687:24:0;-1:-1:-1;;;;;60687:24:0;;;;;;;;;;60564:155::o;59591:191::-;59697:8;;-1:-1:-1;;;;;59697:8:0;59683:10;:22;59675:44;;;;;-1:-1:-1;;;59675:44:0;;;;;;;;;;;;-1:-1:-1;;;59675:44:0;;;;;;;;;;;;;;;59730:20;:44;59591:191::o;84863:216::-;84906:25;84934:24;:22;:24::i;:::-;84906:52;;84969:19;84991:43;85016:17;84991:24;:43::i;:::-;84969:65;;85045:26;85059:11;85045:13;:26::i;:::-;84863:216;;:::o;60727:143::-;60809:8;;-1:-1:-1;;;;;60809:8:0;60795:10;:22;60787:44;;;;;-1:-1:-1;;;60787:44:0;;;;;;;;;;;;-1:-1:-1;;;60787:44:0;;;;;;;;;;;;;;;60842:8;:20;;-1:-1:-1;;;;;;60842:20:0;-1:-1:-1;;;;;60842:20:0;;;;;;;;;;60727:143::o;58737:118::-;58783:7;58817:4;;58810:37;;;-1:-1:-1;;;58810:37:0;;58841:4;58810:37;;;;;;-1:-1:-1;;;;;58817:4:0;;;;58810:22;;:37;;;;;;;;;;;;;;;58817:4;58810:37;;;2:2:-1;;;;27:1;24;17:12;62654:438:0;62787:10;;62732:15;;-1:-1:-1;;;;;62787:10:0;62773;:24;62765:48;;;;;-1:-1:-1;;;62765:48:0;;;;;;;;;;;;-1:-1:-1;;;62765:48:0;;;;;;;;;;;;;;;62824:22;62838:7;62824:13;:22::i;:::-;-1:-1:-1;62876:4:0;;62869:37;;;-1:-1:-1;;;62869:37:0;;62900:4;62869:37;;;;;;-1:-1:-1;;;;;62876:4:0;;;;62869:22;;:37;;;;;;;;;;;;;;;62876:4;62869:37;;;2:2:-1;;;;27:1;24;17:12;2:2;62869:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;62869:37:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;62869:37:0;62948:10;;62919:14;62975:4;;62936:45;;;-1:-1:-1;;;62936:45:0;;-1:-1:-1;;;;;62975:4:0;;;62936:45;;;;;;62869:37;;-1:-1:-1;62919:14:0;;62948:10;;;62936:30;;:45;;;;;62869:37;;62936:45;;;;;;;;62948:10;62936:45;;;2:2:-1;;;;27:1;24;17:12;2:2;62936:45:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;62936:45:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;62936:45:0;;-1:-1:-1;;;;;;63000:20:0;;62992:39;;;;;-1:-1:-1;;;62992:39:0;;;;;;;;;;;;-1:-1:-1;;;62992:39:0;;;;;;;;;;;;;;;63049:4;;63042:42;;-1:-1:-1;;;;;63049:4:0;63068:6;63076:7;63042:42;:25;:42;:::i;:::-;62654:438;;;;:::o;59993:179::-;60093:8;;-1:-1:-1;;;;;60093:8:0;60079:10;:22;60071:44;;;;;-1:-1:-1;;;60071:44:0;;;;;;;;;;;;-1:-1:-1;;;60071:44:0;;;;;;;;;;;;;;;60126:17;:38;59993:179::o;60401:155::-;60487:10;;-1:-1:-1;;;;;60487:10:0;60473;:24;60465:48;;;;;-1:-1:-1;;;60465:48:0;;;;;;;;;;;;-1:-1:-1;;;60465:48:0;;;;;;;;;;;;;;;60524:10;:24;;-1:-1:-1;;;;;;60524:24:0;-1:-1:-1;;;;;60524:24:0;;;;;;;;;;60401:155::o;88772:314::-;88818:13;88841:4;;88834:37;;;-1:-1:-1;;;88834:37:0;;88865:4;88834:37;;;;;;-1:-1:-1;;;;;88841:4:0;;;;88834:22;;:37;;;;;;;;;;;;;;;88841:4;88834:37;;;2:2:-1;;;;27:1;24;17:12;2:2;88834:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;88834:37:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;88834:37:0;;-1:-1:-1;88886:9:0;;88882:197;;88944:1;88919:4;;88912:34;;-1:-1:-1;;;;;88919:4:0;;;;-1:-1:-1;;;;;;;;;;;77197:42:0;88912:34;:24;:34;:::i;:::-;88968:4;;88961:38;;-1:-1:-1;;;;;88968:4:0;-1:-1:-1;;;;;;;;;;;88993:5:0;88961:38;:24;:38;:::i;:::-;-1:-1:-1;;;;;;;;;;;;;;;;89022:20:0;;89043:5;89022:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;89022:27:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;89022:27:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;89022:27:0;:32;89014:53;;;;;-1:-1:-1;;;89014:53:0;;;;;;;;;;;;-1:-1:-1;;;89014:53:0;;;;;;;;;;;;;;;88772:314;:::o;57822:23::-;;;-1:-1:-1;;;;;57822:23:0;;:::o;86444:1368::-;78409:10;78401:19;;;;:7;:19;;;;;;;;;:67;;-1:-1:-1;78441:10:0;78463:4;78441:27;78401:67;:112;;;-1:-1:-1;78503:10:0;;-1:-1:-1;;;;;78503:10:0;78489;:24;78401:112;:157;;;-1:-1:-1;78548:10:0;;-1:-1:-1;;;;;78548:10:0;78534;:24;78401:157;78379:215;;;;;-1:-1:-1;;;78379:215:0;;;;;;;;;;;;-1:-1:-1;;;78379:215:0;;;;;;;;;;;;;;;86522:25:::1;86550:24;:22;:24::i;:::-;86522:52;;86585:16;86604:13;:11;:13::i;:::-;86585:32;;86667:17;86650:13;:34;;:63;;;;;86705:8;86688:13;:25;;86650:63;86628:124;;;::::0;;-1:-1:-1;;;86628:124:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;86628:124:0;;;;;;;;;;;;;::::1;;86802:23;86828:20;:18;:20::i;:::-;86802:46;;86896:23;86922:15;:13;:15::i;:::-;86896:41;;86948:857;87121:13:::0;87089:29:::1;:8:::0;87102:15;87089:29:::1;:12;:29;:::i;:::-;:45;87085:131;;;87173:27;:8:::0;87186:13;87173:27:::1;:12;:27;:::i;:::-;87155:45;;87085:131;-1:-1:-1::0;;;;;;;;;;;;;;;;87258:32:0::1;;87291:15;87258:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24::::0;17:12:::1;2:2;87258:49:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;87258:49:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28::::0;21:12:::1;4:2;-1:-1:::0;87258:49:0;:54;87232:123:::1;;;::::0;;-1:-1:-1;;;87232:123:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;87232:123:0;;;;;;;;;;;;;::::1;;87370:33;77004:42;-1:-1:-1::0;;;;;;;;;;;87401:1:0::1;87370:33;:23;:33;:::i;:::-;87418:47;77004:42;-1:-1:-1::0;;;;;;;;;;;87449:15:0;87418:47:::1;:23;:47;:::i;:::-;-1:-1:-1::0;;;;;;;;;;;;;;;;87488:27:0::1;;87516:15;87488:44;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24::::0;17:12:::1;2:2;87488:44:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;87488:44:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28::::0;21:12:::1;4:2;-1:-1:::0;87488:44:0;:49;87480:68:::1;;;::::0;;-1:-1:-1;;;87480:68:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;87480:68:0;;;;;;;;;;;;;::::1;;87576:29;:8:::0;87589:15;87576:29:::1;:12;:29;:::i;:::-;87565:40:::0;-1:-1:-1;87713:46:0::1;87743:15:::0;87713:25:::1;:15:::0;87733:4:::1;87713:25;:19;:25;:::i;:46::-;87695:64;;87790:13;87779:8;:24;86948:857;;78605:1;;;;86444:1368:::0;:::o;85189:985::-;78409:10;78401:19;;;;:7;:19;;;;;;;;;:67;;-1:-1:-1;78441:10:0;78463:4;78441:27;78401:67;:112;;;-1:-1:-1;78503:10:0;;-1:-1:-1;;;;;78503:10:0;78489;:24;78401:112;:157;;;-1:-1:-1;78548:10:0;;-1:-1:-1;;;;;78548:10:0;78534;:24;78401:157;78379:215;;;;;-1:-1:-1;;;78379:215:0;;;;;;;;;;;;-1:-1:-1;;;78379:215:0;;;;;;;;;;;;;;;85331:16:::1;85350;:14;:16::i;:::-;85331:35;;85377:25;85405:24;:22;:24::i;:::-;85377:52;;85479:17;85462:13;:34;;:113;;;;-1:-1:-1::0;85534:41:0::1;85570:4;85534:31;:17:::0;85556:8;85534:31:::1;:21;:31;:::i;:41::-;85517:13;:58;;85462:113;85440:172;;;::::0;;-1:-1:-1;;;85440:172:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;85440:172:0;;;;;;;;;;;;;::::1;;85707:24;85742:16:::0;85761:13:::1;:11;:13::i;:::-;85742:32;;85785:382;85803:13;85792:8;:24;85785:382;;;85852:15;:13;:15::i;:::-;85833:34:::0;-1:-1:-1;85921:13:0;85888:30:::1;:8:::0;85833:34;85888:30:::1;:12;:30;:::i;:::-;:46;85884:133;;;85974:27;:13:::0;85992:8;85974:27:::1;:17;:27;:::i;:::-;85955:46;;85884:133;-1:-1:-1::0;;;;;;;;;;;;;;;;86033:22:0::1;;86056:16;86033:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24::::0;17:12:::1;2:2;86033:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39::::0;24:38:::1;77:16;74:1;67:27;5:2;86033:40:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28::::0;21:12:::1;4:2;-1:-1:::0;86088:9:0::1;::::0;-1:-1:-1;86088:7:0::1;:9::i;:::-;86125:30;:8:::0;86138:16;86125:30:::1;:12;:30;:::i;:::-;86114:41;;85785:382;;76974:72:::0;77004:42;76974:72;:::o;86182:150::-;86227:25;86255:24;:22;:24::i;:::-;86227:52;;86290:34;86306:17;86290:15;:34::i;57758:25::-;;;-1:-1:-1;;;;;57758:25:0;;:::o;84369:486::-;84401:4;84418:17;84438:14;:12;:14::i;:::-;84418:34;;84463:25;84491:22;:20;:22::i;:::-;84463:50;;84572:17;84560:9;:29;84556:267;;;84606:25;84634:24;:22;:24::i;:::-;84606:52;;84673:19;84695:43;84720:17;84695:24;:43::i;:::-;84673:65;;84755:28;84771:11;84755:15;:28::i;:::-;84807:4;84800:11;;;;;;;;84556:267;84842:5;84835:12;;;;84369:486;:::o;3306:132::-;3364:7;3391:39;3395:1;3398;3391:39;;;;;;;;;;;;;;;;;:3;:39::i;:::-;3384:46;;3306:132;;;;;:::o;1469:136::-;1527:7;1554:43;1558:1;1561;1554:43;;;;;;;;;;;;;;;;;:3;:43::i;2359:471::-;2417:7;2662:6;2658:47;;-1:-1:-1;2692:1:0;2685:8;;2658:47;2729:5;;;2733:1;2729;:5;:1;2753:5;;;;;:10;2745:56;;;;-1:-1:-1;;;2745:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;89094:1273;89188:7;89213:13;89229:15;:13;:15::i;:::-;89213:31;;89267:7;89259:5;:15;89255:1078;;;89291:15;89309:18;:7;89321:5;89309:18;:11;:18;:::i;:::-;89291:36;;89434:7;-1:-1:-1;;;;;;;;;;;;;;;;89405:23:0;;:25;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;89405:25:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;89405:25:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;89405:25:0;:36;;89397:64;;;;;-1:-1:-1;;;89397:64:0;;;;;;;;;;;;-1:-1:-1;;;89397:64:0;;;;;;;;;;;;;;;89539:16;89558:13;:11;:13::i;:::-;89539:32;;89586:16;89605:13;:11;:13::i;:::-;89586:32;;89633:19;89655:20;:18;:20::i;:::-;89633:42;-1:-1:-1;89690:24:0;89717:34;89746:4;89717:24;:7;89633:42;89717:24;:11;:24;:::i;:34::-;89690:61;;89904:8;89885:16;:27;89881:323;;;89933:4;-1:-1:-1;;;;;89933:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;89933:22:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;89933:22:0;;;;89881:323;;;90136:4;:20;90157:30;:8;90170:16;90157:30;:12;:30;:::i;:::-;90136:52;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;90136:52:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;90136:52:0;;;;89881:323;-1:-1:-1;;;;;;;;;;;;;;;;90263:32:0;;90296:7;90263:41;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;90263:41:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;90263:41:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;90263:41:0;:46;90255:66;;;;;-1:-1:-1;;;90255:66:0;;;;;;;;;;;;-1:-1:-1;;;90255:66:0;;;;;;;;;;;;;;;89255:1078;;;;;;-1:-1:-1;90352:7:0;;89094:1273;-1:-1:-1;89094:1273:0:o;1005:181::-;1063:7;1095:5;;;1119:6;;;;1111:46;;;;;-1:-1:-1;;;1111:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;26873:177;26983:58;;;-1:-1:-1;;;;;26983:58:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;26983:58:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;26956:86:0;;26976:5;;26956:19;:86::i;:::-;26873:177;;;:::o;64969:1002::-;-1:-1:-1;;;;;65099:17:0;;65091:26;;12:1:-1;9;2:12;65091:26:0;65187:14;;65161:44;;-1:-1:-1;;;;;65161:25:0;;;;65187:14;;65161:44;:25;:44;:::i;:::-;65242:14;;65216:50;;-1:-1:-1;;;;;65216:25:0;;;;65242:14;65258:7;65216:50;:25;:50;:::i;:::-;65279:21;-1:-1:-1;;;;;65317:12:0;;56992:42;65317:12;;:26;;-1:-1:-1;;;;;;65333:10:0;;56992:42;65333:10;65317:26;65313:452;;;65381:1;65367:16;2:2:-1;65367:16:0;;;;;;;;;;;;;;;;;;;;;;;29:2:-1;21:6;17:15;125:4;109:14;101:6;88:42;144:17;;-1:-1;65367:16:0;;65360:23;;65408:5;65398:4;65403:1;65398:7;;;;;;;;;;;;;:15;-1:-1:-1;;;;;65398:15:0;;;-1:-1:-1;;;;;65398:15:0;;;;;65438:3;65428:4;65433:1;65428:7;;;;;;;;;;;;;:13;-1:-1:-1;;;;;65428:13:0;;;-1:-1:-1;;;;;65428:13:0;;;;;65313:452;;;-1:-1:-1;;;;;65473:14:0;;56913:42;65473:14;;:30;;-1:-1:-1;;;;;;65491:12:0;;56913:42;65491:12;65473:30;65469:296;;;65541:1;65527:16;2:2:-1;;65469:296:0;65651:16;;;65665:1;65651:16;;;;;;;;;;;;;17:15:-1;;109:14;65651:16:0;88:42:-1;144:17;;-1:-1;65651:16:0;65644:23;;65692:5;65682:4;65687:1;65682:7;;;;;;;;;;;;;:15;-1:-1:-1;;;;;65682:15:0;;;-1:-1:-1;;;;;65682:15:0;;;;;56992:42;65712:4;65717:1;65712:7;;;;;;;;;;;;;:13;-1:-1:-1;;;;;65712:13:0;;;-1:-1:-1;;;;;65712:13:0;;;;;65750:3;65740:4;65745:1;65740:7;;;;;;;;;;;;;:13;-1:-1:-1;;;;;65740:13:0;;;-1:-1:-1;;;;;65740:13:0;;;;;65469:296;65801:14;;-1:-1:-1;;;;;65801:14:0;65785:56;65856:7;65801:14;65894:4;65921;65941:11;:3;65949:2;65941:11;:7;:11;:::i;:::-;65785:178;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;65785:178:0;-1:-1:-1;;;;;65785:178:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;65785:178:0;;;;;;;;;;;;;;;;;;;;;;;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;65785:178:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;65785:178:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;65785:178:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;15:2;7:11;;4:2;;;31:1;28;21:12;4:2;65785:178:0;;;;;;;;;;;;;19:11:-1;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;261:11;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;65785:178:0;;421:4:-1;412:14;;;;65785:178:0;;;;;412:14:-1;65785:178:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;65785:178:0;;;;;;;;;;;;64969:1002;;;;:::o;66332:623::-;66400:13;66423:4;;66416:37;;;-1:-1:-1;;;66416:37:0;;66447:4;66416:37;;;;;;-1:-1:-1;;;;;66423:4:0;;;;66416:22;;:37;;;;;;;;;;;;;;;66423:4;66416:37;;;2:2:-1;;;;27:1;24;17:12;2:2;66416:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;66416:37:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;66416:37:0;;-1:-1:-1;66470:9:0;;66466:482;;66582:10;;66570:34;;;-1:-1:-1;;;66570:34:0;;;;66526:173;;-1:-1:-1;;;;;66582:10:0;;66570:32;;:34;;;;;;;;;;;;;;66582:10;66570:34;;;2:2:-1;;;;27:1;24;17:12;2:2;66570:34:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;66570:34:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;66570:34:0;66633:22;;66623:61;;57295:5;;66623:33;;:5;;:33;:9;:33;:::i;66526:173::-;66804:10;;66792:33;;;-1:-1:-1;;;66792:33:0;;;;66748:162;;-1:-1:-1;;;;;66804:10:0;;66792:31;;:33;;;;;;;;;;;;;;66804:10;66792:33;;;2:2:-1;;;;27:1;24;17:12;2:2;66792:33:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;66792:33:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;66792:33:0;66854:17;;66844:51;;57396:5;;66844:28;;:5;;:28;:9;:28;:::i;66748:162::-;66927:9;:7;:9::i;34891:313::-;34968:9;34979:4;34997:13;35012:18;;:::i;:::-;35034:20;35044:1;35047:6;35034:9;:20::i;:::-;34996:58;;-1:-1:-1;34996:58:0;-1:-1:-1;35076:18:0;35069:3;:25;;;;;;;;;35065:73;;-1:-1:-1;35119:3:0;-1:-1:-1;35124:1:0;;-1:-1:-1;35111:15:0;;35065:73;35158:18;35178:17;35187:7;35178:8;:17::i;:::-;35150:46;;;;;;34891:313;;;;;;:::o;63616:82::-;63660:30;63674:15;:13;:15::i;27532:622::-;27902:10;;;27901:62;;-1:-1:-1;27918:39:0;;;-1:-1:-1;;;27918:39:0;;27942:4;27918:39;;;;-1:-1:-1;;;;;27918:39:0;;;;;;;;;:15;;;;;;:39;;;;;;;;;;;;;;;:15;:39;;;2:2:-1;;;;27:1;24;17:12;2:2;27918:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;27918:39:0;;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;27918:39:0;:44;27901:62;27893:152;;;;-1:-1:-1;;;27893:152:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28083:62;;;-1:-1:-1;;;;;28083:62:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;28083:62:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;28056:90:0;;28076:5;;28056:19;:90::i;3934:278::-;4020:7;4055:12;4048:5;4040:28;;;;-1:-1:-1;;;4040:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;4040:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4079:9;4095:1;4091;:5;;;;;;;3934:278;-1:-1:-1;;;;;3934:278:0:o;1908:192::-;1994:7;2030:12;2022:6;;;;2014:29;;;;-1:-1:-1;;;2014:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27:10:-1;;8:100;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;2014:29:0;-1:-1:-1;;;2066:5:0;;;1908:192::o;29178:761::-;29602:23;29628:69;29656:4;29628:69;;;;;;;;;;;;;;;;;29636:5;-1:-1:-1;;;;;29628:27:0;;;:69;;;;;:::i;:::-;29712:17;;29602:95;;-1:-1:-1;29712:21:0;29708:224;;29854:10;29843:30;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;29843:30:0;29835:85;;;;-1:-1:-1;;;29835:85:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34425:353;34494:9;34505:10;;:::i;:::-;34529:14;34545:19;34568:27;34576:1;:10;;;34588:6;34568:7;:27::i;:::-;34528:67;;-1:-1:-1;34528:67:0;-1:-1:-1;34618:18:0;34610:4;:26;;;;;;;;;34606:92;;-1:-1:-1;34667:18:0;;;;;;;;;-1:-1:-1;34667:18:0;;34661:4;;-1:-1:-1;34667:18:0;-1:-1:-1;34653:33:0;;34606:92;34738:31;;;;;;;;;;;;-1:-1:-1;;34738:31:0;;-1:-1:-1;34425:353:0;-1:-1:-1;;;;34425:353:0:o;39702:213::-;39884:12;32737:4;39884:23;;;39702:213::o;12999:196::-;13102:12;13134:53;13157:6;13165:4;13171:1;13174:12;13134:22;:53::i;:::-;13127:60;12999:196;-1:-1:-1;;;;12999:196:0:o;30555:343::-;30611:9;;30643:6;30639:69;;-1:-1:-1;30674:18:0;;-1:-1:-1;30674:18:0;30666:30;;30639:69;30729:5;;;30733:1;30729;:5;:1;30751:5;;;;;:10;30747:144;;-1:-1:-1;30786:26:0;;-1:-1:-1;30814:1:0;;-1:-1:-1;30778:38:0;;30747:144;30857:18;;-1:-1:-1;30877:1:0;-1:-1:-1;30849:30:0;;14376:979;14506:12;14539:18;14550:6;14539:10;:18::i;:::-;14531:60;;;;;-1:-1:-1;;;14531:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;14665:12;14679:23;14706:6;-1:-1:-1;;;;;14706:11:0;14726:8;14737:4;14706:36;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;14706:36:0;;;;;;;;;;;;;;;;;;;;;;;;;12:1:-1;19;14:27;;;;67:4;61:11;56:16;;134:4;130:9;123:4;105:16;101:27;97:43;94:1;90:51;84:4;77:65;157:16;154:1;147:27;211:16;208:1;201:4;198:1;194:12;179:49;5:228;;14:27;32:4;27:9;;5:228;;14664:78:0;;;;14757:7;14753:595;;;14788:10;-1:-1:-1;14781:17:0;;-1:-1:-1;14781:17:0;14753:595;14902:17;;:21;14898:439;;15165:10;15159:17;15226:15;15213:10;15209:2;15205:19;15198:44;15113:148;15301:20;;-1:-1:-1;;;15301:20:0;;;;;;;;;;;;;;;;;15308:12;;15301:20;;;;;;;;;;;;;;;27:10:-1;;8:100;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;10081:422:0;10448:20;10487:8;;;10081:422::o;76795:13575::-;;;;;;;;;;;;;;:::o
Swarm Source
ipfs://a899cd43a52c66b9b94288fdcb322bf1821f4496e65fcd502bb5a1cc64b20be1
Age | Block | Fee Address | BC Fee Address | Voting Power | Jailed | Incoming |
---|
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.