Contract Overview
My Name Tag:
Not Available, login to update
[ Download CSV Export ]
Contract Name:
PolySageMasterChef
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity)
/** *Submitted for verification at polygonscan.com on 2021-10-02 */ // SPDX-License-Identifier: None pragma solidity 0.6.12; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant _NOT_ENTERED = 1; uint256 private constant _ENTERED = 2; uint256 private _status; constructor () internal { _status = _NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and make it call a * `private` function that does the actual work. */ modifier nonReentrant() { // On the first call to nonReentrant, _notEntered will be true require(_status != _ENTERED, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _status = _ENTERED; _; // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = _NOT_ENTERED; } } /* * @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; } } /** * @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, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } /** * @dev Returns the substraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b > a) return (false, 0); return (true, a - b); } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, 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 (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a / b); } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a % b); } /** * @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) { require(b <= a, "SafeMath: subtraction overflow"); return a - b; } /** * @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) { 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, reverting 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) { require(b > 0, "SafeMath: division by zero"); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting 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) { require(b > 0, "SafeMath: modulo by zero"); return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * 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); return a - b; } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryDiv}. * * 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); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * 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; } } /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor () internal { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } /** * @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"); require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: value }(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.staticcall(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { require(isContract(target), "Address: delegate call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.delegatecall(data); return _verifyCallResult(success, returndata, errorMessage); } function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) { 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); } } } } interface IBEP20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the token decimals. */ function decimals() external view returns (uint8); /** * @dev Returns the token symbol. */ function symbol() external view returns (string memory); /** * @dev Returns the token name. */ function name() external view returns (string memory); /** * @dev Returns the bep token owner. */ function getOwner() external view returns (address); /** * @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); } contract BEP20 is Context, IBEP20, Ownable { 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 bep token owner. */ function getOwner() external override view returns (address) { return owner(); } /** * @dev Returns the token name. */ function name() public override view returns (string memory) { return _name; } /** * @dev Returns the token decimals. */ function decimals() public override view returns (uint8) { return _decimals; } /** * @dev Returns the token symbol. */ function symbol() public override view returns (string memory) { return _symbol; } /** * @dev See {BEP20-totalSupply}. */ function totalSupply() public override view returns (uint256) { return _totalSupply; } /** * @dev See {BEP20-balanceOf}. */ function balanceOf(address account) public override view returns (uint256) { return _balances[account]; } /** * @dev See {BEP20-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 override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } /** * @dev See {BEP20-allowance}. */ function allowance(address owner, address spender) public override view returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {BEP20-approve}. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 amount) public override returns (bool) { _approve(_msgSender(), spender, amount); return true; } /** * @dev See {BEP20-transferFrom}. * * Emits an {Approval} event indicating the updated allowance. This is not * required by the EIP. See the note at the beginning of {BEP20}; * * 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 override returns (bool) { _transfer(sender, recipient, amount); _approve( sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "BEP20: 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 {BEP20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. */ function increaseAllowance(address spender, uint256 addedValue) public 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 {BEP20-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 returns (bool) { _approve( _msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero") ); return true; } /** * @dev Creates `amount` tokens and assigns them to `msg.sender`, increasing * the total supply. * * Requirements * * - `msg.sender` must be the token owner */ function mint(uint256 amount) public onlyOwner returns (bool) { _mint(_msgSender(), amount); 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), "BEP20: transfer from the zero address"); require(recipient != address(0), "BEP20: transfer to the zero address"); _balances[sender] = _balances[sender].sub(amount, "BEP20: 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 { require(account != address(0), "BEP20: mint to the zero address"); _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 { require(account != address(0), "BEP20: burn from the zero address"); _balances[account] = _balances[account].sub(amount, "BEP20: 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 is 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 { require(owner != address(0), "BEP20: approve from the zero address"); require(spender != address(0), "BEP20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } /** * @dev Destroys `amount` tokens from `account`.`amount` is then deducted * from the caller's allowance. * * See {_burn} and {_approve}. */ function _burnFrom(address account, uint256 amount) internal { _burn(account, amount); _approve( account, _msgSender(), _allowances[account][_msgSender()].sub(amount, "BEP20: burn amount exceeds allowance") ); } } // SageToken. contract SageToken is BEP20('PolySage Finance', 'SAGE') { /// @notice Creates `_amount` token to `_to`. Must only be called by the owner (MasterChef). function mint(address _to, uint256 _amount) public onlyOwner { _mint(_to, _amount); } } /** * @title SafeBEP20 * @dev Wrappers around BEP20 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 SafeBEP20 for IBEP20;` statement to your contract, * which allows you to call the safe operations as `token.safeTransfer(...)`, etc. */ library SafeBEP20 { using SafeMath for uint256; using Address for address; function safeTransfer( IBEP20 token, address to, uint256 value ) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value)); } function safeTransferFrom( IBEP20 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 * {IBEP20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove( IBEP20 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), "SafeBEP20: approve from non-zero to non-zero allowance" ); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value)); } function safeIncreaseAllowance( IBEP20 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( IBEP20 token, address spender, uint256 value ) internal { uint256 newAllowance = token.allowance(address(this), spender).sub( value, "SafeBEP20: 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(IBEP20 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, "SafeBEP20: low-level call failed"); if (returndata.length > 0) { // Return data is optional // solhint-disable-next-line max-line-length require(abi.decode(returndata, (bool)), "SafeBEP20: BEP20 operation did not succeed"); } } } // MasterChef is the master of SAGE. He can make Sage and he is a fair guy. // // Note that it's ownable and the owner wields tremendous power. The ownership // will be transferred to a governance smart contract once SAGE is sufficiently // distributed and the community can show to govern itself. // // Have fun reading it. Hopefully it's bug-free. God bless. contract PolySageMasterChef is Ownable, ReentrancyGuard { using SafeMath for uint256; using SafeBEP20 for IBEP20; // Info of each user. struct UserInfo { uint256 amount; // How many LP tokens the user has provided. uint256 rewardDebt; // Reward debt. See explanation below. // // We do some fancy math here. Basically, any point in time, the amount of SAGE // entitled to a user but is pending to be distributed is: // // pending reward = (user.amount * pool.accSagePerShare) - user.rewardDebt // // Whenever a user deposits or withdraws LP tokens to a pool. Here's what happens: // 1. The pool's `accSagePerShare` (and `lastRewardBlock`) gets updated. // 2. User receives the pending reward sent to his/her address. // 3. User's `amount` gets updated. // 4. User's `rewardDebt` gets updated. } // Info of each pool. struct PoolInfo { IBEP20 lpToken; // Address of LP token contract. uint256 allocPoint; // How many allocation points assigned to this pool. s to distribute per block. uint256 lastRewardBlock; // Last block number that SAGEs distribution occurs. uint256 accSagePerShare; // Accumulated SAGEs per share, times 1e18. See below. uint16 depositFeeBP; // Deposit fee in basis points uint256 lpSupply; } // The SAGE TOKEN! SageToken public immutable sage; // Dev address. address public devaddr; // SAGE tokens created per block. uint256 public SagePerBlock; // Deposit Fee address address public feeAddress; // Info of each pool. PoolInfo[] public poolInfo; // Info of each user that stakes LP tokens. mapping(uint256 => mapping(address => UserInfo)) public userInfo; // Total allocation points. Must be the sum of all allocation points in all pools. uint256 public totalAllocPoint = 0; // The block number when Sage mining starts. uint256 public startBlock; // Maximum SagePerBlock uint256 public MAX_EMISSION_RATE = 0.01 ether; event Deposit(address indexed user, uint256 indexed pid, uint256 amount); event Withdraw(address indexed user, uint256 indexed pid, uint256 amount); event EmergencyWithdraw(address indexed user, uint256 indexed pid, uint256 amount); event SetFeeAddress(address indexed user, address indexed newAddress); event SetDevAddress(address indexed user, address indexed newAddress); event UpdateEmissionRate(address indexed user, uint256 SagePerBlock); event addPool(uint256 indexed pid, address lpToken, uint256 allocPoint, uint256 depositFeeBP); event setPool(uint256 indexed pid, address lpToken, uint256 allocPoint, uint256 depositFeeBP); event UpdateStartBlock(uint256 newStartBlock); event SageMintError(bytes reason); constructor( SageToken _sage, address _devaddr, address _feeAddress, uint256 _SagePerBlock, uint256 _startBlock ) public { sage = _sage; devaddr = _devaddr; feeAddress = _feeAddress; SagePerBlock = _SagePerBlock; startBlock = _startBlock; } function poolLength() external view returns (uint256) { return poolInfo.length; } mapping(IBEP20 => bool) public poolExistence; modifier nonDuplicated(IBEP20 _lpToken) { require(poolExistence[_lpToken] == false, "nonDuplicated: duplicated"); _; } // Add a new lp to the pool. Can only be called by the owner. function add(uint256 _allocPoint, IBEP20 _lpToken, uint16 _depositFeeBP, bool _withUpdate) external onlyOwner nonDuplicated(_lpToken) { // valid ERC20 token _lpToken.balanceOf(address(this)); require(_depositFeeBP <= 400, "add: invalid deposit fee basis points"); if (_withUpdate) { massUpdatePools(); } uint256 lastRewardBlock = block.number > startBlock ? block.number : startBlock; totalAllocPoint = totalAllocPoint.add(_allocPoint); poolExistence[_lpToken] = true; poolInfo.push( PoolInfo({ lpToken : _lpToken, allocPoint : _allocPoint, lastRewardBlock : lastRewardBlock, accSagePerShare : 0, depositFeeBP : _depositFeeBP, lpSupply: 0 }) ); emit addPool(poolInfo.length - 1, address(_lpToken), _allocPoint, _depositFeeBP); } // Update the given pool's SAGE allocation point and deposit fee. Can only be called by the owner. function set(uint256 _pid, uint256 _allocPoint, uint16 _depositFeeBP, bool _withUpdate) external onlyOwner { require(_depositFeeBP <= 400, "set: invalid deposit fee basis points"); if (_withUpdate) { massUpdatePools(); } totalAllocPoint = totalAllocPoint.sub(poolInfo[_pid].allocPoint).add(_allocPoint); poolInfo[_pid].allocPoint = _allocPoint; poolInfo[_pid].depositFeeBP = _depositFeeBP; emit setPool(_pid, address(poolInfo[_pid].lpToken), _allocPoint, _depositFeeBP); } // Return reward multiplier over the given _from to _to block. function getMultiplier(uint256 _from, uint256 _to) public pure returns (uint256) { return _to.sub(_from); } // View function to see pending Sages on frontend. function pendingSage(uint256 _pid, address _user) external view returns (uint256) { PoolInfo storage pool = poolInfo[_pid]; UserInfo storage user = userInfo[_pid][_user]; uint256 accSagePerShare = pool.accSagePerShare; if (block.number > pool.lastRewardBlock && pool.lpSupply != 0 && totalAllocPoint > 0) { uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number); uint256 sageReward = multiplier.mul(SagePerBlock).mul(pool.allocPoint).div(totalAllocPoint); accSagePerShare = accSagePerShare.add(sageReward.mul(1e18).div(pool.lpSupply)); } return user.amount.mul(accSagePerShare).div(1e18).sub(user.rewardDebt); } // Update reward variables for all pools. Be careful of gas spending! function massUpdatePools() public { uint256 length = poolInfo.length; for (uint256 pid = 0; pid < length; ++pid) { updatePool(pid); } } // Update reward variables of the given pool to be up-to-date. function updatePool(uint256 _pid) public { PoolInfo storage pool = poolInfo[_pid]; if (block.number <= pool.lastRewardBlock) { return; } if (pool.lpSupply == 0 || pool.allocPoint == 0) { pool.lastRewardBlock = block.number; return; } uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number); uint256 sageReward = multiplier.mul(SagePerBlock).mul(pool.allocPoint).div(totalAllocPoint); try sage.mint(devaddr, sageReward.div(10)) { } catch (bytes memory reason) { sageReward = 0; emit SageMintError(reason); } try sage.mint(address(this), sageReward) { } catch (bytes memory reason) { sageReward = 0; emit SageMintError(reason); } pool.accSagePerShare = pool.accSagePerShare.add(sageReward.mul(1e18).div(pool.lpSupply)); pool.lastRewardBlock = block.number; } // Deposit LP tokens to MasterChef for SAGE allocation. function deposit(uint256 _pid, uint256 _amount) external nonReentrant { PoolInfo storage pool = poolInfo[_pid]; UserInfo storage user = userInfo[_pid][msg.sender]; updatePool(_pid); if (user.amount > 0) { uint256 pending = user.amount.mul(pool.accSagePerShare).div(1e18).sub(user.rewardDebt); if (pending > 0) { safeSageTransfer(msg.sender, pending); } } if (_amount > 0) { uint256 balanceBefore = pool.lpToken.balanceOf(address(this)); pool.lpToken.safeTransferFrom(address(msg.sender), address(this), _amount); _amount = pool.lpToken.balanceOf(address(this)) - balanceBefore; if (pool.depositFeeBP > 0) { uint256 depositFee = _amount.mul(pool.depositFeeBP).div(10000); pool.lpToken.safeTransfer(feeAddress, depositFee); user.amount = user.amount.add(_amount).sub(depositFee); pool.lpSupply = pool.lpSupply.add(_amount).sub(depositFee); } else { user.amount = user.amount.add(_amount); pool.lpSupply = pool.lpSupply.add(_amount); } } user.rewardDebt = user.amount.mul(pool.accSagePerShare).div(1e18); emit Deposit(msg.sender, _pid, _amount); } // Withdraw LP tokens from MasterChef. function withdraw(uint256 _pid, uint256 _amount) external nonReentrant { PoolInfo storage pool = poolInfo[_pid]; UserInfo storage user = userInfo[_pid][msg.sender]; require(user.amount >= _amount, "withdraw: not good"); updatePool(_pid); uint256 pending = user.amount.mul(pool.accSagePerShare).div(1e18).sub(user.rewardDebt); if (pending > 0) { safeSageTransfer(msg.sender, pending); } if (_amount > 0) { user.amount = user.amount.sub(_amount); pool.lpToken.safeTransfer(address(msg.sender), _amount); pool.lpSupply = pool.lpSupply.sub(_amount); } user.rewardDebt = user.amount.mul(pool.accSagePerShare).div(1e18); emit Withdraw(msg.sender, _pid, _amount); } // Withdraw without caring about rewards. EMERGENCY ONLY. function emergencyWithdraw(uint256 _pid) external nonReentrant { PoolInfo storage pool = poolInfo[_pid]; UserInfo storage user = userInfo[_pid][msg.sender]; uint256 amount = user.amount; user.amount = 0; user.rewardDebt = 0; pool.lpToken.safeTransfer(address(msg.sender), amount); if (pool.lpSupply >= amount) { pool.lpSupply = pool.lpSupply.sub(amount); } else { pool.lpSupply = 0; } emit EmergencyWithdraw(msg.sender, _pid, amount); } // Safe sage transfer function, just in case if rounding error causes pool to not have enough SAGEs. function safeSageTransfer(address _to, uint256 _amount) internal { uint256 sageBal = sage.balanceOf(address(this)); bool transferSuccess = false; if (_amount > sageBal) { transferSuccess = sage.transfer(_to, sageBal); } else { transferSuccess = sage.transfer(_to, _amount); } require(transferSuccess, "safeSageTransfer: transfer failed"); } // Update dev address. function setDevAddress(address _devaddr) external { require(msg.sender == devaddr, "dev: wut?"); require(_devaddr != address(0), "!nonzero"); devaddr = _devaddr; emit SetDevAddress(msg.sender, _devaddr); } function setFeeAddress(address _feeAddress) external { require(msg.sender == feeAddress, "setFeeAddress: FORBIDDEN"); require(_feeAddress != address(0), "!nonzero"); feeAddress = _feeAddress; emit SetFeeAddress(msg.sender, _feeAddress); } // Pancake has to add hidden dummy pools inorder to alter the emission, here we make it simple and transparent to all. function updateEmissionRate(uint256 _SagePerBlock) external onlyOwner { require(_SagePerBlock <= MAX_EMISSION_RATE, "Too high"); massUpdatePools(); SagePerBlock = _SagePerBlock; emit UpdateEmissionRate(msg.sender, _SagePerBlock); } // Only update before start of farm function updateStartBlock(uint256 _newStartBlock) external onlyOwner { require(block.number < startBlock, "cannot change start block if farm has already started"); require(block.number < _newStartBlock, "cannot set start block in the past"); uint256 length = poolInfo.length; for (uint256 pid = 0; pid < length; ++pid) { PoolInfo storage pool = poolInfo[pid]; pool.lastRewardBlock = _newStartBlock; } startBlock = _newStartBlock; emit UpdateStartBlock(startBlock); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"contract SageToken","name":"_sage","type":"address"},{"internalType":"address","name":"_devaddr","type":"address"},{"internalType":"address","name":"_feeAddress","type":"address"},{"internalType":"uint256","name":"_SagePerBlock","type":"uint256"},{"internalType":"uint256","name":"_startBlock","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Deposit","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"EmergencyWithdraw","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bytes","name":"reason","type":"bytes"}],"name":"SageMintError","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"SetDevAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"SetFeeAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"SagePerBlock","type":"uint256"}],"name":"UpdateEmissionRate","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newStartBlock","type":"uint256"}],"name":"UpdateStartBlock","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Withdraw","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"address","name":"lpToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"allocPoint","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"depositFeeBP","type":"uint256"}],"name":"addPool","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"address","name":"lpToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"allocPoint","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"depositFeeBP","type":"uint256"}],"name":"setPool","type":"event"},{"inputs":[],"name":"MAX_EMISSION_RATE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SagePerBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"contract IBEP20","name":"_lpToken","type":"address"},{"internalType":"uint16","name":"_depositFeeBP","type":"uint16"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"add","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"devaddr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_from","type":"uint256"},{"internalType":"uint256","name":"_to","type":"uint256"}],"name":"getMultiplier","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"massUpdatePools","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"address","name":"_user","type":"address"}],"name":"pendingSage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"contract IBEP20","name":"","type":"address"}],"name":"poolExistence","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"poolInfo","outputs":[{"internalType":"contract IBEP20","name":"lpToken","type":"address"},{"internalType":"uint256","name":"allocPoint","type":"uint256"},{"internalType":"uint256","name":"lastRewardBlock","type":"uint256"},{"internalType":"uint256","name":"accSagePerShare","type":"uint256"},{"internalType":"uint16","name":"depositFeeBP","type":"uint16"},{"internalType":"uint256","name":"lpSupply","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"poolLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sage","outputs":[{"internalType":"contract SageToken","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"uint16","name":"_depositFeeBP","type":"uint16"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"set","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_devaddr","type":"address"}],"name":"setDevAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_feeAddress","type":"address"}],"name":"setFeeAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalAllocPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_SagePerBlock","type":"uint256"}],"name":"updateEmissionRate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"updatePool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newStartBlock","type":"uint256"}],"name":"updateStartBlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"address","name":"","type":"address"}],"name":"userInfo","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"rewardDebt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
60a06040526000600755662386f26fc100006009553480156200002157600080fd5b506040516200396b3803806200396b833981810160405260a08110156200004757600080fd5b8101908080519060200190929190805190602001909291908051906020019092919080519060200190929190805190602001909291905050506000620000926200020960201b60201c565b9050806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a350600180819055508473ffffffffffffffffffffffffffffffffffffffff1660808173ffffffffffffffffffffffffffffffffffffffff1660601b8152505083600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555082600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508160038190555080600881905550505050505062000211565b600033905090565b60805160601c613723620002486000398061095c5280610dea5280610f9e5280612d505280612e1e5280612ef152506137236000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c806384e82a33116100f9578063cbd258b511610097578063d963842211610071578063d9638422146106ca578063e2bbb1581461071c578063f2fde38b14610754578063fac2b9ba14610798576101a9565b8063cbd258b5146105f8578063d0d41fe114610652578063d49e77cd14610696576101a9565b80638dbb1e3a116100d35780638dbb1e3a146104c357806393f1a40b1461050f578063c7ebfce214610578578063c8a8642d14610596576101a9565b806384e82a33146103e35780638705fcd41461044b5780638da5cb5b1461048f576101a9565b8063436cc3d61161016657806351eb05a61161014057806351eb05a6146103735780635312ea8e146103a1578063630b5ba1146103cf578063715018a6146103d9576101a9565b8063436cc3d6146102ff578063441a3e701461031d57806348cd4cb114610355576101a9565b8063081e3eda146101ae5780630ba84cd2146101cc5780630bd49c58146101fa5780631526fe271461022e57806317caf6f1146102ad57806341275358146102cb575b600080fd5b6101b66107c6565b6040518082815260200191505060405180910390f35b6101f8600480360360208110156101e257600080fd5b81019080803590602001909291905050506107d3565b005b61020261095a565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b61025a6004803603602081101561024457600080fd5b810190808035906020019092919050505061097e565b604051808773ffffffffffffffffffffffffffffffffffffffff1681526020018681526020018581526020018481526020018361ffff168152602001828152602001965050505050505060405180910390f35b6102b56109f5565b6040518082815260200191505060405180910390f35b6102d36109fb565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b610307610a21565b6040518082815260200191505060405180910390f35b6103536004803603604081101561033357600080fd5b810190808035906020019092919080359060200190929190505050610a27565b005b61035d610d32565b6040518082815260200191505060405180910390f35b61039f6004803603602081101561038957600080fd5b8101908080359060200190929190505050610d38565b005b6103cd600480360360208110156103b757600080fd5b810190808035906020019092919050505061117a565b005b6103d7611370565b005b6103e161139d565b005b610449600480360360808110156103f957600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803561ffff16906020019092919080351515906020019092919050505061150a565b005b61048d6004803603602081101561046157600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611995565b005b610497611b99565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6104f9600480360360408110156104d957600080fd5b810190808035906020019092919080359060200190929190505050611bc2565b6040518082815260200191505060405180910390f35b61055b6004803603604081101561052557600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611bdf565b604051808381526020018281526020019250505060405180910390f35b610580611c10565b6040518082815260200191505060405180910390f35b6105e2600480360360408110156105ac57600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611c16565b6040518082815260200191505060405180910390f35b61063a6004803603602081101561060e57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611dad565b60405180821515815260200191505060405180910390f35b6106946004803603602081101561066857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611dcd565b005b61069e611fd1565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b61071a600480360360808110156106e057600080fd5b810190808035906020019092919080359060200190929190803561ffff169060200190929190803515159060200190929190505050611ff7565b005b6107526004803603604081101561073257600080fd5b810190808035906020019092919080359060200190929190505050612261565b005b6107966004803603602081101561076a57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506127d1565b005b6107c4600480360360208110156107ae57600080fd5b81019080803590602001909291905050506129c3565b005b6000600580549050905090565b6107db612bb2565b73ffffffffffffffffffffffffffffffffffffffff166107f9611b99565b73ffffffffffffffffffffffffffffffffffffffff1614610882576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b6009548111156108fa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260088152602001807f546f6f206869676800000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b610902611370565b806003819055503373ffffffffffffffffffffffffffffffffffffffff167fe2492e003bbe8afa53088b406f0c1cb5d9e280370fc72a74cf116ffd343c4053826040518082815260200191505060405180910390a250565b7f000000000000000000000000000000000000000000000000000000000000000081565b6005818154811061098b57fe5b90600052602060002090600602016000915090508060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16908060010154908060020154908060030154908060040160009054906101000a900461ffff16908060050154905086565b60075481565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60095481565b60026001541415610aa0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0081525060200191505060405180910390fd5b6002600181905550600060058381548110610ab757fe5b9060005260206000209060060201905060006006600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090508281600001541015610b95576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260128152602001807f77697468647261773a206e6f7420676f6f64000000000000000000000000000081525060200191505060405180910390fd5b610b9e84610d38565b6000610beb8260010154610bdd670de0b6b3a7640000610bcf87600301548760000154612bba90919063ffffffff16565b612c4090919063ffffffff16565b612cc990919063ffffffff16565b90506000811115610c0157610c003382612d4c565b5b6000841115610c9857610c21848360000154612cc990919063ffffffff16565b8260000181905550610c7833858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661301a9092919063ffffffff16565b610c8f848460050154612cc990919063ffffffff16565b83600501819055505b610ccd670de0b6b3a7640000610cbf85600301548560000154612bba90919063ffffffff16565b612c4090919063ffffffff16565b8260010181905550843373ffffffffffffffffffffffffffffffffffffffff167ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568866040518082815260200191505060405180910390a3505050600180819055505050565b60085481565b600060058281548110610d4757fe5b9060005260206000209060060201905080600201544311610d685750611177565b600081600501541480610d7f575060008160010154145b15610d935743816002018190555050611177565b6000610da3826002015443611bc2565b90506000610de6600754610dd88560010154610dca60035487612bba90919063ffffffff16565b612bba90919063ffffffff16565b612c4090919063ffffffff16565b90507f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff166340c10f19600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16610e5b600a85612c4090919063ffffffff16565b6040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b158015610eae57600080fd5b505af1925050508015610ebf575060015b610f9b573d8060008114610eef576040519150601f19603f3d011682016040523d82523d6000602084013e610ef4565b606091505b50600091507f4476297eab2212025c3a8cdd96588d7099b1107632a83f5cefa6de9b976436e5816040518080602001828103825283818151815260200191508051906020019080838360005b83811015610f5b578082015181840152602081019050610f40565b50505050905090810190601f168015610f885780820380516001836020036101000a031916815260200191505b509250505060405180910390a150610f9c565b5b7f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff166340c10f1930836040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b15801561102d57600080fd5b505af192505050801561103e575060015b61111a573d806000811461106e576040519150601f19603f3d011682016040523d82523d6000602084013e611073565b606091505b50600091507f4476297eab2212025c3a8cdd96588d7099b1107632a83f5cefa6de9b976436e5816040518080602001828103825283818151815260200191508051906020019080838360005b838110156110da5780820151818401526020810190506110bf565b50505050905090810190601f1680156111075780820380516001836020036101000a031916815260200191505b509250505060405180910390a15061111b565b5b61116261114f8460050154611141670de0b6b3a764000085612bba90919063ffffffff16565b612c4090919063ffffffff16565b84600301546130bc90919063ffffffff16565b83600301819055504383600201819055505050505b50565b600260015414156111f3576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0081525060200191505060405180910390fd5b600260018190555060006005828154811061120a57fe5b9060005260206000209060060201905060006006600084815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905060008160000154905060008260000181905550600082600101819055506112da33828560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661301a9092919063ffffffff16565b80836005015410611309576112fc818460050154612cc990919063ffffffff16565b8360050181905550611314565b600083600501819055505b833373ffffffffffffffffffffffffffffffffffffffff167fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae0595836040518082815260200191505060405180910390a35050506001808190555050565b6000600580549050905060005b818110156113995761138e81610d38565b80600101905061137d565b5050565b6113a5612bb2565b73ffffffffffffffffffffffffffffffffffffffff166113c3611b99565b73ffffffffffffffffffffffffffffffffffffffff161461144c576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b611512612bb2565b73ffffffffffffffffffffffffffffffffffffffff16611530611b99565b73ffffffffffffffffffffffffffffffffffffffff16146115b9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8260001515600a60008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16151514611680576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260198152602001807f6e6f6e4475706c6963617465643a206475706c6963617465640000000000000081525060200191505060405180910390fd5b8373ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156116e757600080fd5b505afa1580156116fb573d6000803e3d6000fd5b505050506040513d602081101561171157600080fd5b8101908080519060200190929190505050506101908361ffff161115611782576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260258152602001806135b76025913960400191505060405180910390fd5b811561179157611790611370565b5b600060085443116117a4576008546117a6565b435b90506117bd866007546130bc90919063ffffffff16565b6007819055506001600a60008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555060056040518060c001604052808773ffffffffffffffffffffffffffffffffffffffff168152602001888152602001838152602001600081526020018661ffff1681526020016000815250908060018154018082558091505060019003906000526020600020906006020160009091909190915060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160010155604082015181600201556060820151816003015560808201518160040160006101000a81548161ffff021916908361ffff16021790555060a0820151816005015550506001600580549050037faa6642278d4bbef86d8990c37355d5d4dfe365c194106bdf7a65162268606f07868887604051808473ffffffffffffffffffffffffffffffffffffffff1681526020018381526020018261ffff168152602001935050505060405180910390a2505050505050565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611a58576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260188152602001807f736574466565416464726573733a20464f5242494444454e000000000000000081525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415611afb576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260088152602001807f216e6f6e7a65726f00000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b80600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167fd44190acf9d04bdb5d3a1aafff7e6dee8b40b93dfb8c5d3f0eea4b9f4539c3f760405160405180910390a350565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6000611bd78383612cc990919063ffffffff16565b905092915050565b6006602052816000526040600020602052806000526040600020600091509150508060000154908060010154905082565b60035481565b60008060058481548110611c2657fe5b9060005260206000209060060201905060006006600086815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000209050600082600301549050826002015443118015611cab57506000836005015414155b8015611cb957506000600754115b15611d5b576000611cce846002015443611bc2565b90506000611d11600754611d038760010154611cf560035487612bba90919063ffffffff16565b612bba90919063ffffffff16565b612c4090919063ffffffff16565b9050611d56611d478660050154611d39670de0b6b3a764000085612bba90919063ffffffff16565b612c4090919063ffffffff16565b846130bc90919063ffffffff16565b925050505b611da28260010154611d94670de0b6b3a7640000611d86858760000154612bba90919063ffffffff16565b612c4090919063ffffffff16565b612cc990919063ffffffff16565b935050505092915050565b600a6020528060005260406000206000915054906101000a900460ff1681565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611e90576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260098152602001807f6465763a207775743f000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415611f33576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260088152602001807f216e6f6e7a65726f00000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b80600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f618c54559e94f1499a808aad71ee8729f8e74e8c48e979616328ce493a1a52e760405160405180910390a350565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b611fff612bb2565b73ffffffffffffffffffffffffffffffffffffffff1661201d611b99565b73ffffffffffffffffffffffffffffffffffffffff16146120a6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b6101908261ffff161115612105576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260258152602001806136946025913960400191505060405180910390fd5b801561211457612113611370565b5b6121598361214b6005878154811061212857fe5b906000526020600020906006020160010154600754612cc990919063ffffffff16565b6130bc90919063ffffffff16565b600781905550826005858154811061216d57fe5b906000526020600020906006020160010181905550816005858154811061219057fe5b906000526020600020906006020160040160006101000a81548161ffff021916908361ffff160217905550837f39f0c3d078af018954b4fa56832a05a2b511afaa999b133ea3f1c487c21ed287600586815481106121ea57fe5b906000526020600020906006020160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff168585604051808473ffffffffffffffffffffffffffffffffffffffff1681526020018381526020018261ffff168152602001935050505060405180910390a250505050565b600260015414156122da576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0081525060200191505060405180910390fd5b60026001819055506000600583815481106122f157fe5b9060005260206000209060060201905060006006600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061235e84610d38565b6000816000015411156123d05760006123b882600101546123aa670de0b6b3a764000061239c87600301548760000154612bba90919063ffffffff16565b612c4090919063ffffffff16565b612cc990919063ffffffff16565b905060008111156123ce576123cd3382612d4c565b5b505b60008311156127385760008260000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561246657600080fd5b505afa15801561247a573d6000803e3d6000fd5b505050506040513d602081101561249057600080fd5b810190808051906020019092919050505090506124f43330868660000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16613144909392919063ffffffff16565b808360000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561258057600080fd5b505afa158015612594573d6000803e3d6000fd5b505050506040513d60208110156125aa57600080fd5b810190808051906020019092919050505003935060008360040160009054906101000a900461ffff1661ffff1611156126f757600061261c61271061260e8660040160009054906101000a900461ffff1661ffff1688612bba90919063ffffffff16565b612c4090919063ffffffff16565b905061268f600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16828660000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661301a9092919063ffffffff16565b6126b8816126aa8786600001546130bc90919063ffffffff16565b612cc990919063ffffffff16565b83600001819055506126e9816126db8787600501546130bc90919063ffffffff16565b612cc990919063ffffffff16565b846005018190555050612736565b61270e8483600001546130bc90919063ffffffff16565b826000018190555061272d8484600501546130bc90919063ffffffff16565b83600501819055505b505b61276d670de0b6b3a764000061275f84600301548460000154612bba90919063ffffffff16565b612c4090919063ffffffff16565b8160010181905550833373ffffffffffffffffffffffffffffffffffffffff167f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a15856040518082815260200191505060405180910390a35050600180819055505050565b6127d9612bb2565b73ffffffffffffffffffffffffffffffffffffffff166127f7611b99565b73ffffffffffffffffffffffffffffffffffffffff1614612880576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415612906576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806136066026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6129cb612bb2565b73ffffffffffffffffffffffffffffffffffffffff166129e9611b99565b73ffffffffffffffffffffffffffffffffffffffff1614612a72576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b6008544310612acc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260358152602001806136b96035913960400191505060405180910390fd5b804310612b24576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260228152602001806135956022913960400191505060405180910390fd5b6000600580549050905060005b81811015612b6d57600060058281548110612b4857fe5b9060005260206000209060060201905083816002018190555050806001019050612b31565b50816008819055507f1ff2238e284780b094bb341b41af7e6ce294dee1da3799ae49cd0e29fbe127096008546040518082815260200191505060405180910390a15050565b600033905090565b600080831415612bcd5760009050612c3a565b6000828402905082848281612bde57fe5b0414612c35576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260218152602001806136736021913960400191505060405180910390fd5b809150505b92915050565b6000808211612cb7576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601a8152602001807f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525060200191505060405180910390fd5b818381612cc057fe5b04905092915050565b600082821115612d41576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601e8152602001807f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525060200191505060405180910390fd5b818303905092915050565b60007f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b158015612dd557600080fd5b505afa158015612de9573d6000803e3d6000fd5b505050506040513d6020811015612dff57600080fd5b81019080805190602001909291905050509050600081831115612eef577f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb85846040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b158015612ead57600080fd5b505af1158015612ec1573d6000803e3d6000fd5b505050506040513d6020811015612ed757600080fd5b81019080805190602001909291905050509050612fbe565b7f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb85856040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b158015612f8057600080fd5b505af1158015612f94573d6000803e3d6000fd5b505050506040513d6020811015612faa57600080fd5b810190808051906020019092919050505090505b80613014576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260218152602001806136526021913960400191505060405180910390fd5b50505050565b6130b78363a9059cbb60e01b8484604051602401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050613205565b505050565b60008082840190508381101561313a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601b8152602001807f536166654d6174683a206164646974696f6e206f766572666c6f77000000000081525060200191505060405180910390fd5b8091505092915050565b6131ff846323b872dd60e01b858585604051602401808473ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019350505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050613205565b50505050565b6060613267826040518060400160405280602081526020017f5361666542455032303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff166132f49092919063ffffffff16565b90506000815111156132ef5780806020019051602081101561328857600080fd5b81019080805190602001909291905050506132ee576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602a8152602001806135dc602a913960400191505060405180910390fd5b5b505050565b6060613303848460008561330c565b90509392505050565b606082471015613367576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602681526020018061362c6026913960400191505060405180910390fd5b613370856134b5565b6133e2576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601d8152602001807f416464726573733a2063616c6c20746f206e6f6e2d636f6e747261637400000081525060200191505060405180910390fd5b600060608673ffffffffffffffffffffffffffffffffffffffff1685876040518082805190602001908083835b60208310613432578051825260208201915060208101905060208303925061340f565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114613494576040519150601f19603f3d011682016040523d82523d6000602084013e613499565b606091505b50915091506134a98282866134c8565b92505050949350505050565b600080823b905060008111915050919050565b606083156134d85782905061358d565b6000835111156134eb5782518084602001fd5b816040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015613552578082015181840152602081019050613537565b50505050905090810190601f16801561357f5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b939250505056fe63616e6e6f742073657420737461727420626c6f636b20696e2074686520706173746164643a20696e76616c6964206465706f7369742066656520626173697320706f696e74735361666542455032303a204245503230206f7065726174696f6e20646964206e6f7420737563636565644f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373416464726573733a20696e73756666696369656e742062616c616e636520666f722063616c6c73616665536167655472616e736665723a207472616e73666572206661696c6564536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f777365743a20696e76616c6964206465706f7369742066656520626173697320706f696e747363616e6e6f74206368616e676520737461727420626c6f636b206966206661726d2068617320616c72656164792073746172746564a26469706673582212203f1bac1668d1661d82b5f915977cbf5cf7078a1d3b16f44b9f5d244fd88a681464736f6c634300060c00330000000000000000000000002ed945dc703d85c80225d95abde41cdee14e1992000000000000000000000000c6dc917e71404351c022a3573228972640a3526a000000000000000000000000deb837ca95c4edfae016a2e93d136c459a8ee9930000000000000000000000000000000000000000000000000018de76816d800000000000000000000000000000000000000000000000000000000000773593ff
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000002ed945dc703d85c80225d95abde41cdee14e1992000000000000000000000000c6dc917e71404351c022a3573228972640a3526a000000000000000000000000deb837ca95c4edfae016a2e93d136c459a8ee9930000000000000000000000000000000000000000000000000018de76816d800000000000000000000000000000000000000000000000000000000000773593ff
-----Decoded View---------------
Arg [0] : _sage (address): 0x2ed945dc703d85c80225d95abde41cdee14e1992
Arg [1] : _devaddr (address): 0xc6dc917e71404351c022a3573228972640a3526a
Arg [2] : _feeAddress (address): 0xdeb837ca95c4edfae016a2e93d136c459a8ee993
Arg [3] : _SagePerBlock (uint256): 7000000000000000
Arg [4] : _startBlock (uint256): 1999999999
-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 0000000000000000000000002ed945dc703d85c80225d95abde41cdee14e1992
Arg [1] : 000000000000000000000000c6dc917e71404351c022a3573228972640a3526a
Arg [2] : 000000000000000000000000deb837ca95c4edfae016a2e93d136c459a8ee993
Arg [3] : 0000000000000000000000000000000000000000000000000018de76816d8000
Arg [4] : 00000000000000000000000000000000000000000000000000000000773593ff
Deployed ByteCode Sourcemap
37697:12761:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;41021:95;;;:::i;:::-;;;;;;;;;;;;;;;;;;;49572:272;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;39203:31;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;39453:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39694:34;;;:::i;:::-;;;;;;;;;;;;;;;;;;;39392:25;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;39848:45;;;:::i;:::-;;;;;;;;;;;;;;;;;;;46883:814;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;39785:25;;;:::i;:::-;;;;;;;;;;;;;;;;;;;44360:1032;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;47768:562;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;44104:180;;;:::i;:::-;;12603:148;;;:::i;:::-;;41391:977;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;49161:279;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;11952:87;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;43111:121;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;39535:64;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;39330:27;;;:::i;:::-;;;;;;;;;;;;;;;;;;;43296:725;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;41124:44;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;48905:248;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;39262:22;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;42480:555;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;45465:1366;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;12906:244;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;49893:562;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;41021:95;41066:7;41093:8;:15;;;;41086:22;;41021:95;:::o;49572:272::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49678:17:::1;;49661:13;:34;;49653:55;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;49719:17;:15;:17::i;:::-;49762:13;49747:12;:28;;;;49810:10;49791:45;;;49822:13;49791:45;;;;;;;;;;;;;;;;;;49572:272:::0;:::o;39203:31::-;;;:::o;39453:26::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;39694:34::-;;;;:::o;39392:25::-;;;;;;;;;;;;;:::o;39848:45::-;;;;:::o;46883:814::-;1712:1;2318:7;;:19;;2310:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1712:1;2451:7;:18;;;;46965:21:::1;46989:8;46998:4;46989:14;;;;;;;;;;;;;;;;;;46965:38;;47014:21;47038:8;:14;47047:4;47038:14;;;;;;;;;;;:26;47053:10;47038:26;;;;;;;;;;;;;;;47014:50;;47098:7;47083:4;:11;;;:22;;47075:53;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;47139:16;47150:4;47139:10;:16::i;:::-;47166:15;47184:68;47236:4;:15;;;47184:47;47226:4;47184:37;47200:4;:20;;;47184:4;:11;;;:15;;:37;;;;:::i;:::-;:41;;:47;;;;:::i;:::-;:51;;:68;;;;:::i;:::-;47166:86;;47277:1;47267:7;:11;47263:81;;;47295:37;47312:10;47324:7;47295:16;:37::i;:::-;47263:81;47368:1;47358:7;:11;47354:209;;;47400:24;47416:7;47400:4;:11;;;:15;;:24;;;;:::i;:::-;47386:4;:11;;:38;;;;47439:55;47473:10;47486:7;47439:4;:12;;;;;;;;;;;;:25;;;;:55;;;;;:::i;:::-;47525:26;47543:7;47525:4;:13;;;:17;;:26;;;;:::i;:::-;47509:4;:13;;:42;;;;47354:209;47591:47;47633:4;47591:37;47607:4;:20;;;47591:4;:11;;;:15;;:37;;;;:::i;:::-;:41;;:47;;;;:::i;:::-;47573:4;:15;;:65;;;;47675:4;47663:10;47654:35;;;47681:7;47654:35;;;;;;;;;;;;;;;;;;2482:1;;;1668::::0;2630:7;:22;;;;46883:814;;:::o;39785:25::-;;;;:::o;44360:1032::-;44412:21;44436:8;44445:4;44436:14;;;;;;;;;;;;;;;;;;44412:38;;44481:4;:20;;;44465:12;:36;44461:75;;44518:7;;;44461:75;44567:1;44550:4;:13;;;:18;:42;;;;44591:1;44572:4;:15;;;:20;44550:42;44546:131;;;44632:12;44609:4;:20;;:35;;;;44659:7;;;44546:131;44687:18;44708:49;44722:4;:20;;;44744:12;44708:13;:49::i;:::-;44687:70;;44768:18;44789:70;44843:15;;44789:49;44822:4;:15;;;44789:28;44804:12;;44789:10;:14;;:28;;;;:::i;:::-;:32;;:49;;;;:::i;:::-;:53;;:70;;;;:::i;:::-;44768:91;;44884:4;:9;;;44894:7;;;;;;;;;;;44903:18;44918:2;44903:10;:14;;:18;;;;:::i;:::-;44884:38;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44880:166;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44992:1;44979:14;;45013:21;45027:6;45013:21;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44936:110;44880:166;;;;45070:4;:9;;;45088:4;45095:10;45070:36;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;45066:164;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;45176:1;45163:14;;45197:21;45211:6;45197:21;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;45120:110;45066:164;;;;45273:65;45298:39;45323:4;:13;;;45298:20;45313:4;45298:10;:14;;:20;;;;:::i;:::-;:24;;:39;;;;:::i;:::-;45273:4;:20;;;:24;;:65;;;;:::i;:::-;45250:4;:20;;:88;;;;45372:12;45349:4;:20;;:35;;;;44360:1032;;;;;:::o;47768:562::-;1712:1;2318:7;;:19;;2310:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1712:1;2451:7;:18;;;;47842:21:::1;47866:8;47875:4;47866:14;;;;;;;;;;;;;;;;;;47842:38;;47891:21;47915:8;:14;47924:4;47915:14;;;;;;;;;;;:26;47930:10;47915:26;;;;;;;;;;;;;;;47891:50;;47952:14;47969:4;:11;;;47952:28;;48005:1;47991:4;:11;;:15;;;;48035:1;48017:4;:15;;:19;;;;48047:54;48081:10;48094:6;48047:4;:12;;;;;;;;;;;;:25;;;;:54;;;;;:::i;:::-;48136:6;48118:4;:13;;;:24;48114:148;;48175:25;48193:6;48175:4;:13;;;:17;;:25;;;;:::i;:::-;48159:4;:13;;:41;;;;48114:148;;;48249:1;48233:4;:13;;:17;;;;48114:148;48309:4;48297:10;48279:43;;;48315:6;48279:43;;;;;;;;;;;;;;;;;;2482:1;;;1668::::0;2630:7;:22;;;;47768:562;:::o;44104:180::-;44149:14;44166:8;:15;;;;44149:32;;44197:11;44192:85;44220:6;44214:3;:12;44192:85;;;44250:15;44261:3;44250:10;:15::i;:::-;44228:5;;;;;44192:85;;;;44104:180;:::o;12603:148::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12710:1:::1;12673:40;;12694:6;::::0;::::1;;;;;;;;12673:40;;;;;;;;;;;;12741:1;12724:6:::0;::::1;:19;;;;;;;;;;;;;;;;;;12603:148::o:0;41391:977::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;41515:8:::1;41261:5;41234:32;;:13;:23;41248:8;41234:23;;;;;;;;;;;;;;;;;;;;;;;;;:32;;;41226:70;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;41566:8:::2;:18;;;41593:4;41566:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::2;;;;;;;;;;;;::::0;::::2;;;;;;;;;;;;;;;;;;;::::0;::::2;;;;;;;;;;;;;;;;;;;41637:3;41620:13;:20;;;;41612:70;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;41697:11;41693:61;;;41725:17;:15;:17::i;:::-;41693:61;41764:23;41805:10;;41790:12;:25;:53;;41833:10;;41790:53;;;41818:12;41790:53;41764:79;;41872:32;41892:11;41872:15;;:19;;:32;;;;:::i;:::-;41854:15;:50;;;;41941:4;41915:13;:23;41929:8;41915:23;;;;;;;;;;;;;;;;:30;;;;;;;;;;;;;;;;;;41956:8;41984:272;;;;;;;;42022:8;41984:272;;;;;;42062:11;41984:272;;;;42110:15;41984:272;;;;42162:1;41984:272;;;;42197:13;41984:272;;;;;;42239:1;41984:272;;::::0;41956:311:::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42311:1;42293:8;:15;;;;:19;42285:75;42322:8;42333:11;42346:13;42285:75;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;41307:1;12243::::1;41391:977:::0;;;;:::o;49161:279::-;49247:10;;;;;;;;;;;49233:24;;:10;:24;;;49225:61;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49328:1;49305:25;;:11;:25;;;;49297:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49367:11;49354:10;;:24;;;;;;;;;;;;;;;;;;49420:11;49394:38;;49408:10;49394:38;;;;;;;;;;;;49161:279;:::o;11952:87::-;11998:7;12025:6;;;;;;;;;;;12018:13;;11952:87;:::o;43111:121::-;43183:7;43210:14;43218:5;43210:3;:7;;:14;;;;:::i;:::-;43203:21;;43111:121;;;;:::o;39535:64::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;39330:27::-;;;;:::o;43296:725::-;43369:7;43389:21;43413:8;43422:4;43413:14;;;;;;;;;;;;;;;;;;43389:38;;43438:21;43462:8;:14;43471:4;43462:14;;;;;;;;;;;:21;43477:5;43462:21;;;;;;;;;;;;;;;43438:45;;43494:23;43520:4;:20;;;43494:46;;43570:4;:20;;;43555:12;:35;:57;;;;;43611:1;43594:4;:13;;;:18;;43555:57;:80;;;;;43634:1;43616:15;;:19;43555:80;43551:382;;;43652:18;43673:49;43687:4;:20;;;43709:12;43673:13;:49::i;:::-;43652:70;;43737:18;43758:70;43812:15;;43758:49;43791:4;:15;;;43758:28;43773:12;;43758:10;:14;;:28;;;;:::i;:::-;:32;;:49;;;;:::i;:::-;:53;;:70;;;;:::i;:::-;43737:91;;43861:60;43881:39;43906:4;:13;;;43881:20;43896:4;43881:10;:14;;:20;;;;:::i;:::-;:24;;:39;;;;:::i;:::-;43861:15;:19;;:60;;;;:::i;:::-;43843:78;;43551:382;;;43950:63;43997:4;:15;;;43950:42;43987:4;43950:32;43966:15;43950:4;:11;;;:15;;:32;;;;:::i;:::-;:36;;:42;;;;:::i;:::-;:46;;:63;;;;:::i;:::-;43943:70;;;;;43296:725;;;;:::o;41124:44::-;;;;;;;;;;;;;;;;;;;;;;:::o;48905:248::-;48988:7;;;;;;;;;;;48974:21;;:10;:21;;;48966:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49048:1;49028:22;;:8;:22;;;;49020:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49086:8;49076:7;;:18;;;;;;;;;;;;;;;;;;49136:8;49110:35;;49124:10;49110:35;;;;;;;;;;;;48905:248;:::o;39262:22::-;;;;;;;;;;;;;:::o;42480:555::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42623:3:::1;42606:13;:20;;;;42598:70;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42683:11;42679:61;;;42711:17;:15;:17::i;:::-;42679:61;42768:63;42819:11;42768:46;42788:8;42797:4;42788:14;;;;;;;;;;;;;;;;;;:25;;;42768:15;;:19;;:46;;;;:::i;:::-;:50;;:63;;;;:::i;:::-;42750:15;:81;;;;42870:11;42842:8;42851:4;42842:14;;;;;;;;;;;;;;;;;;:25;;:39;;;;42922:13;42892:8;42901:4;42892:14;;;;;;;;;;;;;;;;;;:27;;;:43;;;;;;;;;;;;;;;;;;42961:4;42953:74;42975:8;42984:4;42975:14;;;;;;;;;;;;;;;;;;:22;;;;;;;;;;;;43000:11;43013:13;42953:74;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42480:555:::0;;;;:::o;45465:1366::-;1712:1;2318:7;;:19;;2310:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1712:1;2451:7;:18;;;;45546:21:::1;45570:8;45579:4;45570:14;;;;;;;;;;;;;;;;;;45546:38;;45595:21;45619:8;:14;45628:4;45619:14;;;;;;;;;;;:26;45634:10;45619:26;;;;;;;;;;;;;;;45595:50;;45656:16;45667:4;45656:10;:16::i;:::-;45701:1;45687:4;:11;;;:15;45683:237;;;45719:15;45737:68;45789:4;:15;;;45737:47;45779:4;45737:37;45753:4;:20;;;45737:4;:11;;;:15;;:37;;;;:::i;:::-;:41;;:47;;;;:::i;:::-;:51;;:68;;;;:::i;:::-;45719:86;;45834:1;45824:7;:11;45820:89;;;45856:37;45873:10;45885:7;45856:16;:37::i;:::-;45820:89;45683:237;;45944:1;45934:7;:11;45930:768;;;45962:21;45986:4;:12;;;;;;;;;;;;:22;;;46017:4;45986:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;45962:61;;46038:74;46076:10;46097:4;46104:7;46038:4;:12;;;;;;;;;;;;:29;;;;:74;;;;;;:::i;:::-;46177:13;46137:4;:12;;;;;;;;;;;;:22;;;46168:4;46137:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;:53;46127:63;;46229:1;46209:4;:17;;;;;;;;;;;;:21;;;46205:482;;;46251:18;46272:41;46307:5;46272:30;46284:4;:17;;;;;;;;;;;;46272:30;;:7;:11;;:30;;;;:::i;:::-;:34;;:41;;;;:::i;:::-;46251:62;;46332:49;46358:10;;;;;;;;;;;46370;46332:4;:12;;;;;;;;;;;;:25;;;;:49;;;;;:::i;:::-;46414:40;46443:10;46414:24;46430:7;46414:4;:11;;;:15;;:24;;;;:::i;:::-;:28;;:40;;;;:::i;:::-;46400:4;:11;;:54;;;;46489:42;46520:10;46489:26;46507:7;46489:4;:13;;;:17;;:26;;;;:::i;:::-;:30;;:42;;;;:::i;:::-;46473:4;:13;;:58;;;;46205:482;;;;46586:24;46602:7;46586:4;:11;;;:15;;:24;;;;:::i;:::-;46572:4;:11;;:38;;;;46645:26;46663:7;46645:4;:13;;;:17;;:26;;;;:::i;:::-;46629:4;:13;;:42;;;;46205:482;45930:768;;46726:47;46768:4;46726:37;46742:4;:20;;;46726:4;:11;;;:15;;:37;;;;:::i;:::-;:41;;:47;;;;:::i;:::-;46708:4;:15;;:65;;;;46809:4;46797:10;46789:34;;;46815:7;46789:34;;;;;;;;;;;;;;;;;;2482:1;;1668::::0;2630:7;:22;;;;45465:1366;;:::o;12906:244::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13015:1:::1;12995:22;;:8;:22;;;;12987:73;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13105:8;13076:38;;13097:6;::::0;::::1;;;;;;;;13076:38;;;;;;;;;;;;13134:8;13125:6;::::0;:17:::1;;;;;;;;;;;;;;;;;;12906:244:::0;:::o;49893:562::-;12183:12;:10;:12::i;:::-;12172:23;;:7;:5;:7::i;:::-;:23;;;12164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49996:10:::1;;49981:12;:25;49973:91;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50098:14;50083:12;:29;50075:76;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50162:14;50179:8;:15;;;;50162:32;;50210:11;50205:159;50233:6;50227:3;:12;50205:159;;;50263:21;50287:8;50296:3;50287:13;;;;;;;;;;;;;;;;;;50263:37;;50338:14;50315:4;:20;;:37;;;;50205:159;50241:5;;;;;50205:159;;;;50387:14;50374:10;:27;;;;50419:28;50436:10;;50419:28;;;;;;;;;;;;;;;;;;12243:1;49893:562:::0;:::o;3210:106::-;3263:15;3298:10;3291:17;;3210:106;:::o;7147:220::-;7205:7;7234:1;7229;:6;7225:20;;;7244:1;7237:8;;;;7225:20;7256:9;7272:1;7268;:5;7256:17;;7301:1;7296;7292;:5;;;;;;:10;7284:56;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7358:1;7351:8;;;7147:220;;;;;:::o;7845:153::-;7903:7;7935:1;7931;:5;7923:44;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7989:1;7985;:5;;;;;;7978:12;;7845:153;;;;:::o;6730:158::-;6788:7;6821:1;6816;:6;;6808:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6879:1;6875;:5;6868:12;;6730:158;;;;:::o;48444:425::-;48520:15;48538:4;:14;;;48561:4;48538:29;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48520:47;;48578:20;48631:7;48621;:17;48617:173;;;48673:4;:13;;;48687:3;48692:7;48673:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48655:45;;48617:173;;;48751:4;:13;;;48765:3;48770:7;48751:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48733:45;;48617:173;48808:15;48800:61;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48444:425;;;;:::o;34013:211::-;34130:86;34150:5;34180:23;;;34205:2;34209:5;34157:58;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34130:19;:86::i;:::-;34013:211;;;:::o;6268:179::-;6326:7;6346:9;6362:1;6358;:5;6346:17;;6387:1;6382;:6;;6374:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6438:1;6431:8;;;6268:179;;;;:::o;34232:248::-;34376:96;34396:5;34426:27;;;34455:4;34461:2;34465:5;34403:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34376:19;:96::i;:::-;34232:248;;;;:::o;36548:774::-;36972:23;36998:69;37026:4;36998:69;;;;;;;;;;;;;;;;;37006:5;36998:27;;;;:69;;;;;:::i;:::-;36972:95;;37102:1;37082:10;:17;:21;37078:237;;;37237:10;37226:30;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37218:85;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37078:237;36548:774;;;:::o;16756:195::-;16859:12;16891:52;16913:6;16921:4;16927:1;16930:12;16891:21;:52::i;:::-;16884:59;;16756:195;;;;;:::o;17808:530::-;17935:12;17993:5;17968:21;:30;;17960:81;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18060:18;18071:6;18060:10;:18::i;:::-;18052:60;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18186:12;18200:23;18227:6;:11;;18247:5;18255:4;18227:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18185:75;;;;18278:52;18296:7;18305:10;18317:12;18278:17;:52::i;:::-;18271:59;;;;17808:530;;;;;;:::o;13838:422::-;13898:4;14106:12;14217:7;14205:20;14197:28;;14251:1;14244:4;:8;14237:15;;;13838:422;;;:::o;20348:742::-;20463:12;20492:7;20488:595;;;20523:10;20516:17;;;;20488:595;20657:1;20637:10;:17;:21;20633:439;;;20900:10;20894:17;20961:15;20948:10;20944:2;20940:19;20933:44;20848:148;21043:12;21036:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20348:742;;;;;;:::o
Swarm Source
ipfs://3f1bac1668d1661d82b5f915977cbf5cf7078a1d3b16f44b9f5d244fd88a6814
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.