ETH Price: $1,895.84 (-1.08%)
 

Overview

ETH Balance

0.000070598014473405 ETH

Eth Value

$0.13 (@ $1,895.84/ETH)

Token Holdings

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Approve203003992024-07-13 21:54:35242 days ago1720907675IN
0xfF151579...07c47ad28
0 ETH0.000072051.56019435
Set Fees149365002022-06-10 4:26:021007 days ago1654835162IN
0xfF151579...07c47ad28
0 ETH0.0028396442.63276685
Trigger Zeus Buy...149364832022-06-10 4:21:501007 days ago1654834910IN
0xfF151579...07c47ad28
0 ETH0.0080146153.99846757
Approve148085072022-05-20 2:26:181028 days ago1653013578IN
0xfF151579...07c47ad28
0 ETH0.001796238.62315635
Approve148031902022-05-19 5:25:551029 days ago1652937955IN
0xfF151579...07c47ad28
0 ETH0.0007573616.37822064
Set Is Dividend ...147845012022-05-16 5:44:341032 days ago1652679874IN
0xfF151579...07c47ad28
0 ETH0.0022786316.22950935
Transfer147844902022-05-16 5:42:321032 days ago1652679752IN
0xfF151579...07c47ad28
0 ETH0.0125002522.31862297
Approve145994942022-04-17 0:05:341061 days ago1650153934IN
0xfF151579...07c47ad28
0 ETH0.0006045713
Approve144914612022-03-31 3:06:101078 days ago1648695970IN
0xfF151579...07c47ad28
0 ETH0.00159734.33985462
Set Fees144827762022-03-29 18:38:371079 days ago1648579117IN
0xfF151579...07c47ad28
0 ETH0.0014675532.8525928
Approve144803322022-03-29 9:29:511080 days ago1648546191IN
0xfF151579...07c47ad28
0 ETH0.0016163534.75592241
Approve144799572022-03-29 8:05:431080 days ago1648541143IN
0xfF151579...07c47ad28
0 ETH0.001017921.88763185
Approve144797262022-03-29 7:20:281080 days ago1648538428IN
0xfF151579...07c47ad28
0 ETH0.0011083223.83186893
Approve144796992022-03-29 7:15:371080 days ago1648538137IN
0xfF151579...07c47ad28
0 ETH0.0011710725.18107724
Approve144796752022-03-29 7:11:551080 days ago1648537915IN
0xfF151579...07c47ad28
0 ETH0.0016670735.84638089

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Method Block
From
To
Add Liquidity ET...217356722025-01-30 6:50:2342 days ago1738219823
0xfF151579...07c47ad28
0.00000094 ETH
Transfer217356722025-01-30 6:50:2342 days ago1738219823
0xfF151579...07c47ad28
0.00000189 ETH
Deposit217356722025-01-30 6:50:2342 days ago1738219823
0xfF151579...07c47ad28
0.00000189 ETH
Transfer217356722025-01-30 6:50:2342 days ago1738219823
0xfF151579...07c47ad28
0.00000662 ETH
Add Liquidity ET...203004052024-07-13 21:55:47242 days ago1720907747
0xfF151579...07c47ad28
0.00000243 ETH
Transfer203004052024-07-13 21:55:47242 days ago1720907747
0xfF151579...07c47ad28
0.00000487 ETH
Deposit203004052024-07-13 21:55:47242 days ago1720907747
0xfF151579...07c47ad28
0.00000487 ETH
Transfer203004052024-07-13 21:55:47242 days ago1720907747
0xfF151579...07c47ad28
0.00001707 ETH
-149364832022-06-10 4:21:501007 days ago1654834910
0xfF151579...07c47ad28
0.000014 ETH
-148961722022-06-03 8:48:281014 days ago1654246108
0xfF151579...07c47ad28
0.00000354 ETH
-148961722022-06-03 8:48:281014 days ago1654246108
0xfF151579...07c47ad28
0.00001064 ETH
-148961722022-06-03 8:48:281014 days ago1654246108
0xfF151579...07c47ad28
0.00000177 ETH
-148961722022-06-03 8:48:281014 days ago1654246108
0xfF151579...07c47ad28
0.00001596 ETH
-148087212022-05-20 3:16:451028 days ago1653016605
0xfF151579...07c47ad28
0.0000203 ETH
-148087212022-05-20 3:16:451028 days ago1653016605
0xfF151579...07c47ad28
0.00006092 ETH
-148087212022-05-20 3:16:451028 days ago1653016605
0xfF151579...07c47ad28
0.00001015 ETH
-148087212022-05-20 3:16:451028 days ago1653016605
0xfF151579...07c47ad28
0.00009139 ETH
-148085042022-05-20 2:25:021028 days ago1653013502
0xfF151579...07c47ad28
0.00002038 ETH
-148085042022-05-20 2:25:021028 days ago1653013502
0xfF151579...07c47ad28
0.00006116 ETH
-148085042022-05-20 2:25:021028 days ago1653013502
0xfF151579...07c47ad28
0.00001019 ETH
-148085042022-05-20 2:25:021028 days ago1653013502
0xfF151579...07c47ad28
0.00009174 ETH
-148032332022-05-19 5:34:251029 days ago1652938465
0xfF151579...07c47ad28
0.00002046 ETH
-148032332022-05-19 5:34:251029 days ago1652938465
0xfF151579...07c47ad28
0.00006139 ETH
-148032332022-05-19 5:34:251029 days ago1652938465
0xfF151579...07c47ad28
0.00001023 ETH
-148032332022-05-19 5:34:251029 days ago1652938465
0xfF151579...07c47ad28
0.00009209 ETH
View All Internal Transactions
Loading...
Loading

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0x41c1Fb8d...BFEf85FA4
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
BuybackBabyToken

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-02-05
*/

// Dependency file: @openzeppelin/contracts/utils/math/SafeMath.sol

// SPDX-License-Identifier: MIT

// pragma solidity ^0.8.0;

// CAUTION
// This version of SafeMath should only be used with Solidity 0.8 or later,
// because it relies on the compiler's built in overflow checks.

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is no longer needed starting with Solidity 0.8. The compiler
 * now has built in overflow checking.
 */
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) {
        unchecked {
            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) {
        unchecked {
            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) {
        unchecked {
            // 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) {
        unchecked {
            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) {
        unchecked {
            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) {
        return a + b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return 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) {
        return a * b;
    }

    /**
     * @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.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        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) {
        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) {
        unchecked {
            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.
     *
     * 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) {
        unchecked {
            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) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}


// Dependency file: @openzeppelin/contracts/proxy/Clones.sol


// pragma solidity ^0.8.0;

/**
 * @dev https://eips.ethereum.org/EIPS/eip-1167[EIP 1167] is a standard for
 * deploying minimal proxy contracts, also known as "clones".
 *
 * > To simply and cheaply clone contract functionality in an immutable way, this standard specifies
 * > a minimal bytecode implementation that delegates all calls to a known, fixed address.
 *
 * The library includes functions to deploy a proxy using either `create` (traditional deployment) or `create2`
 * (salted deterministic deployment). It also includes functions to predict the addresses of clones deployed using the
 * deterministic method.
 *
 * _Available since v3.4._
 */
library Clones {
    /**
     * @dev Deploys and returns the address of a clone that mimics the behaviour of `implementation`.
     *
     * This function uses the create opcode, which should never revert.
     */
    function clone(address implementation) internal returns (address instance) {
        assembly {
            let ptr := mload(0x40)
            mstore(ptr, 0x3d602d80600a3d3981f3363d3d373d3d3d363d73000000000000000000000000)
            mstore(add(ptr, 0x14), shl(0x60, implementation))
            mstore(add(ptr, 0x28), 0x5af43d82803e903d91602b57fd5bf30000000000000000000000000000000000)
            instance := create(0, ptr, 0x37)
        }
        require(instance != address(0), "ERC1167: create failed");
    }

    /**
     * @dev Deploys and returns the address of a clone that mimics the behaviour of `implementation`.
     *
     * This function uses the create2 opcode and a `salt` to deterministically deploy
     * the clone. Using the same `implementation` and `salt` multiple time will revert, since
     * the clones cannot be deployed twice at the same address.
     */
    function cloneDeterministic(address implementation, bytes32 salt) internal returns (address instance) {
        assembly {
            let ptr := mload(0x40)
            mstore(ptr, 0x3d602d80600a3d3981f3363d3d373d3d3d363d73000000000000000000000000)
            mstore(add(ptr, 0x14), shl(0x60, implementation))
            mstore(add(ptr, 0x28), 0x5af43d82803e903d91602b57fd5bf30000000000000000000000000000000000)
            instance := create2(0, ptr, 0x37, salt)
        }
        require(instance != address(0), "ERC1167: create2 failed");
    }

    /**
     * @dev Computes the address of a clone deployed using {Clones-cloneDeterministic}.
     */
    function predictDeterministicAddress(
        address implementation,
        bytes32 salt,
        address deployer
    ) internal pure returns (address predicted) {
        assembly {
            let ptr := mload(0x40)
            mstore(ptr, 0x3d602d80600a3d3981f3363d3d373d3d3d363d73000000000000000000000000)
            mstore(add(ptr, 0x14), shl(0x60, implementation))
            mstore(add(ptr, 0x28), 0x5af43d82803e903d91602b57fd5bf3ff00000000000000000000000000000000)
            mstore(add(ptr, 0x38), shl(0x60, deployer))
            mstore(add(ptr, 0x4c), salt)
            mstore(add(ptr, 0x6c), keccak256(ptr, 0x37))
            predicted := keccak256(add(ptr, 0x37), 0x55)
        }
    }

    /**
     * @dev Computes the address of a clone deployed using {Clones-cloneDeterministic}.
     */
    function predictDeterministicAddress(address implementation, bytes32 salt)
        internal
        view
        returns (address predicted)
    {
        return predictDeterministicAddress(implementation, salt, address(this));
    }
}


// Dependency file: contracts/interfaces/IUniswapV2Factory.sol

// pragma solidity >=0.5.0;

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    function feeTo() external view returns (address);

    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB)
        external
        view
        returns (address pair);

    function allPairs(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}


// Dependency file: contracts/interfaces/IUniswapV2Router02.sol

// pragma solidity >=0.6.2;

interface IUniswapV2Router01 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETH(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountToken, uint256 amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountToken, uint256 amountETH);

    function swapExactTokensForTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapTokensForExactTokens(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactETHForTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function swapTokensForExactETH(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactTokensForETH(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapETHForExactTokens(
        uint256 amountOut,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function quote(
        uint256 amountA,
        uint256 reserveA,
        uint256 reserveB
    ) external pure returns (uint256 amountB);

    function getAmountOut(
        uint256 amountIn,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountOut);

    function getAmountIn(
        uint256 amountOut,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountIn);

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);

    function getAmountsIn(uint256 amountOut, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountETH);

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}


// Dependency file: contracts/interfaces/IERC20Extended.sol

// pragma solidity =0.8.4;

interface IERC20Extended {
    function totalSupply() external view returns (uint256);

    function decimals() external view returns (uint8);

    function symbol() external view returns (string memory);

    function name() external view returns (string memory);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    function allowance(address _owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}


// Dependency file: contracts/buyback/Auth.sol

// pragma solidity =0.8.4;

abstract contract Auth {
    address internal owner;
    mapping(address => bool) internal authorizations;

    constructor(address _owner) {
        owner = _owner;
        authorizations[_owner] = true;
    }

    /**
     * Function modifier to require caller to be contract owner
     */
    modifier onlyOwner() {
        require(isOwner(msg.sender), "!OWNER");
        _;
    }

    /**
     * Function modifier to require caller to be authorized
     */
    modifier authorized() {
        require(isAuthorized(msg.sender), "!AUTHORIZED");
        _;
    }

    /**
     * Authorize address. Owner only
     */
    function authorize(address adr) public onlyOwner {
        authorizations[adr] = true;
    }

    /**
     * Remove address' authorization. Owner only
     */
    function unauthorize(address adr) public onlyOwner {
        authorizations[adr] = false;
    }

    /**
     * Check if address is owner
     */
    function isOwner(address account) public view returns (bool) {
        return account == owner;
    }

    /**
     * Return address' authorization status
     */
    function isAuthorized(address adr) public view returns (bool) {
        return authorizations[adr];
    }

    /**
     * Transfer ownership to new address. Caller must be owner. Leaves old owner authorized
     */
    function transferOwnership(address payable adr) public onlyOwner {
        owner = adr;
        authorizations[adr] = true;
        emit OwnershipTransferred(adr);
    }

    event OwnershipTransferred(address owner);
}


// Dependency file: contracts/buyback/DividendDistributor.sol

// pragma solidity =0.8.4;

// import "@openzeppelin/contracts/utils/math/SafeMath.sol";
// import "contracts/interfaces/IUniswapV2Router02.sol";
// import "contracts/interfaces/IERC20Extended.sol";

interface IDividendDistributor {
    function setDistributionCriteria(
        uint256 _minPeriod,
        uint256 _minDistribution
    ) external;

    function setShare(address shareholder, uint256 amount) external;

    function deposit() external payable;

    function process(uint256 gas) external;
}

contract DividendDistributor is IDividendDistributor {
    using SafeMath for uint256;

    address public _token;

    struct Share {
        uint256 amount;
        uint256 totalExcluded;
        uint256 totalRealised;
    }

    IERC20Extended public rewardToken;
    IUniswapV2Router02 public router;

    address[] public shareholders;
    mapping(address => uint256) public shareholderIndexes;
    mapping(address => uint256) public shareholderClaims;

    mapping(address => Share) public shares;

    uint256 public totalShares;
    uint256 public totalDividends;
    uint256 public totalDistributed;
    uint256 public dividendsPerShare;
    uint256 public dividendsPerShareAccuracyFactor;

    uint256 public minPeriod;
    uint256 public minDistribution;

    uint256 currentIndex;

    bool initialized;
    modifier initializer() {
        require(!initialized);
        _;
        initialized = true;
    }

    modifier onlyToken() {
        require(msg.sender == _token);
        _;
    }

    constructor(address rewardToken_, address router_) {
        _token = msg.sender;
        rewardToken = IERC20Extended(rewardToken_);
        router = IUniswapV2Router02(router_);

        dividendsPerShareAccuracyFactor = 10**36;
        minPeriod = 1 hours;
        minDistribution = 1 * (10**rewardToken.decimals());
    }

    function setDistributionCriteria(
        uint256 _minPeriod,
        uint256 _minDistribution
    ) external override onlyToken {
        minPeriod = _minPeriod;
        minDistribution = _minDistribution;
    }

    function setShare(address shareholder, uint256 amount)
        external
        override
        onlyToken
    {
        if (shares[shareholder].amount > 0) {
            distributeDividend(shareholder);
        }

        if (amount > 0 && shares[shareholder].amount == 0) {
            addShareholder(shareholder);
        } else if (amount == 0 && shares[shareholder].amount > 0) {
            removeShareholder(shareholder);
        }

        totalShares = totalShares.sub(shares[shareholder].amount).add(amount);
        shares[shareholder].amount = amount;
        shares[shareholder].totalExcluded = getCumulativeDividends(
            shares[shareholder].amount
        );
    }

    function deposit() external payable override onlyToken {
        uint256 balanceBefore = rewardToken.balanceOf(address(this));

        address[] memory path = new address[](2);
        path[0] = router.WETH();
        path[1] = address(rewardToken);

        router.swapExactETHForTokensSupportingFeeOnTransferTokens{
            value: msg.value
        }(0, path, address(this), block.timestamp);

        uint256 amount = rewardToken.balanceOf(address(this)).sub(
            balanceBefore
        );

        totalDividends = totalDividends.add(amount);
        dividendsPerShare = dividendsPerShare.add(
            dividendsPerShareAccuracyFactor.mul(amount).div(totalShares)
        );
    }

    function process(uint256 gas) external override onlyToken {
        uint256 shareholderCount = shareholders.length;

        if (shareholderCount == 0) {
            return;
        }

        uint256 gasUsed = 0;
        uint256 gasLeft = gasleft();

        uint256 iterations = 0;

        while (gasUsed < gas && iterations < shareholderCount) {
            if (currentIndex >= shareholderCount) {
                currentIndex = 0;
            }

            if (shouldDistribute(shareholders[currentIndex])) {
                distributeDividend(shareholders[currentIndex]);
            }

            gasUsed = gasUsed.add(gasLeft.sub(gasleft()));
            gasLeft = gasleft();
            currentIndex++;
            iterations++;
        }
    }

    function shouldDistribute(address shareholder)
        internal
        view
        returns (bool)
    {
        return
            shareholderClaims[shareholder] + minPeriod < block.timestamp &&
            getUnpaidEarnings(shareholder) > minDistribution;
    }

    function distributeDividend(address shareholder) internal {
        if (shares[shareholder].amount == 0) {
            return;
        }

        uint256 amount = getUnpaidEarnings(shareholder);
        if (amount > 0) {
            totalDistributed = totalDistributed.add(amount);
            rewardToken.transfer(shareholder, amount);
            shareholderClaims[shareholder] = block.timestamp;
            shares[shareholder].totalRealised = shares[shareholder]
                .totalRealised
                .add(amount);
            shares[shareholder].totalExcluded = getCumulativeDividends(
                shares[shareholder].amount
            );
        }
    }

    function claimDividend() external {
        distributeDividend(msg.sender);
    }

    function getUnpaidEarnings(address shareholder)
        public
        view
        returns (uint256)
    {
        if (shares[shareholder].amount == 0) {
            return 0;
        }

        uint256 shareholderTotalDividends = getCumulativeDividends(
            shares[shareholder].amount
        );
        uint256 shareholderTotalExcluded = shares[shareholder].totalExcluded;

        if (shareholderTotalDividends <= shareholderTotalExcluded) {
            return 0;
        }

        return shareholderTotalDividends.sub(shareholderTotalExcluded);
    }

    function getCumulativeDividends(uint256 share)
        internal
        view
        returns (uint256)
    {
        return
            share.mul(dividendsPerShare).div(dividendsPerShareAccuracyFactor);
    }

    function addShareholder(address shareholder) internal {
        shareholderIndexes[shareholder] = shareholders.length;
        shareholders.push(shareholder);
    }

    function removeShareholder(address shareholder) internal {
        shareholders[shareholderIndexes[shareholder]] = shareholders[
            shareholders.length - 1
        ];
        shareholderIndexes[
            shareholders[shareholders.length - 1]
        ] = shareholderIndexes[shareholder];
        shareholders.pop();
    }
}


// Dependency file: contracts/BaseToken.sol

// pragma solidity =0.8.4;

enum TokenType {
    standard,
    antiBotStandard,
    liquidityGenerator,
    antiBotLiquidityGenerator,
    baby,
    antiBotBaby,
    buybackBaby,
    antiBotBuybackBaby
}

abstract contract BaseToken {
    event TokenCreated(
        address indexed owner,
        address indexed token,
        TokenType tokenType,
        uint256 version
    );
}


// Root file: contracts/buyback/BuybackBabyToken.sol

pragma solidity =0.8.4;

// import "@openzeppelin/contracts/utils/math/SafeMath.sol";
// import "@openzeppelin/contracts/proxy/Clones.sol";
// import "contracts/interfaces/IUniswapV2Factory.sol";
// import "contracts/interfaces/IUniswapV2Router02.sol";
// import "contracts/interfaces/IERC20Extended.sol";
// import "contracts/buyback/Auth.sol";
// import "contracts/buyback/DividendDistributor.sol";
// import "contracts/BaseToken.sol";

contract BuybackBabyToken is IERC20Extended, Auth, BaseToken {
    using SafeMath for uint256;

    uint256 public constant VERSION = 1;

    address private constant DEAD = address(0xdead);
    address private constant ZERO = address(0);
    uint8 private constant _decimals = 9;

    string private _name;
    string private _symbol;
    uint256 private _totalSupply;

    address public rewardToken;
    IUniswapV2Router02 public router;
    address public pair;
    address public autoLiquidityReceiver;
    address public marketingFeeReceiver;

    uint256 public liquidityFee; // default: 200
    uint256 public buybackFee; // default: 300
    uint256 public reflectionFee; // default: 800
    uint256 public marketingFee; // default: 100
    uint256 public totalFee;
    uint256 public feeDenominator; // default: 10000

    uint256 public targetLiquidity; // default: 25
    uint256 public targetLiquidityDenominator; // default: 100

    uint256 public buybackMultiplierNumerator; // default: 200
    uint256 public buybackMultiplierDenominator; // default: 100
    uint256 public buybackMultiplierTriggeredAt;
    uint256 public buybackMultiplierLength; // default: 30 mins

    bool public autoBuybackEnabled;

    uint256 public autoBuybackCap;
    uint256 public autoBuybackAccumulator;
    uint256 public autoBuybackAmount;
    uint256 public autoBuybackBlockPeriod;
    uint256 public autoBuybackBlockLast;

    DividendDistributor public distributor;

    uint256 public distributorGas;

    bool public swapEnabled;
    uint256 public swapThreshold;

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;

    mapping(address => bool) public buyBacker;
    mapping(address => bool) public isFeeExempt;
    mapping(address => bool) public isDividendExempt;

    event AutoLiquify(uint256 amountBNB, uint256 amountBOG);
    event BuybackMultiplierActive(uint256 duration);

    bool inSwap;
    modifier swapping() {
        inSwap = true;
        _;
        inSwap = false;
    }

    modifier onlyBuybacker() {
        require(buyBacker[msg.sender] == true, "Not a buybacker");
        _;
    }

    constructor(
        string memory name_,
        string memory symbol_,
        uint256 totalSupply_,
        address rewardToken_,
        address router_,
        uint256[5] memory feeSettings_,
        address serviceFeeReceiver_,
        uint256 serviceFee_
    ) payable Auth(msg.sender) {
        _name = name_;
        _symbol = symbol_;
        _totalSupply = totalSupply_;

        rewardToken = rewardToken_;
        router = IUniswapV2Router02(router_);
        pair = IUniswapV2Factory(router.factory()).createPair(
            address(this),
            router.WETH()
        );
        distributor = new DividendDistributor(rewardToken_, router_);

        _initializeFees(feeSettings_);
        _initializeLiquidityBuyBack();

        distributorGas = 500000;
        swapEnabled = true;
        swapThreshold = _totalSupply / 20000; // 0.005%

        isFeeExempt[msg.sender] = true;
        isDividendExempt[pair] = true;
        isDividendExempt[address(this)] = true;
        isDividendExempt[DEAD] = true;
        buyBacker[msg.sender] = true;

        autoLiquidityReceiver = msg.sender;
        marketingFeeReceiver = msg.sender;

        _allowances[address(this)][address(router)] = _totalSupply;
        _allowances[address(this)][address(pair)] = _totalSupply;

        _balances[msg.sender] = _totalSupply;
        emit Transfer(address(0), msg.sender, _totalSupply);

        emit TokenCreated(
            msg.sender,
            address(this),
            TokenType.buybackBaby,
            VERSION
        );

        payable(serviceFeeReceiver_).transfer(serviceFee_);
    }

    function _initializeFees(uint256[5] memory feeSettings_) internal {
        _setFees(
            feeSettings_[0], // liquidityFee
            feeSettings_[1], // buybackFee
            feeSettings_[2], // reflectionFee
            feeSettings_[3], // marketingFee
            feeSettings_[4] // feeDenominator
        );
    }

    function _initializeLiquidityBuyBack() internal {
        targetLiquidity = 25;
        targetLiquidityDenominator = 100;

        buybackMultiplierNumerator = 200;
        buybackMultiplierDenominator = 100;
        buybackMultiplierLength = 30 minutes;
    }

    receive() external payable {}

    function totalSupply() external view override returns (uint256) {
        return _totalSupply;
    }

    function decimals() external pure override returns (uint8) {
        return _decimals;
    }

    function symbol() external view override returns (string memory) {
        return _symbol;
    }

    function name() external view override returns (string memory) {
        return _name;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function allowance(address holder, address spender)
        external
        view
        override
        returns (uint256)
    {
        return _allowances[holder][spender];
    }

    function approve(address spender, uint256 amount)
        public
        override
        returns (bool)
    {
        _allowances[msg.sender][spender] = amount;
        emit Approval(msg.sender, spender, amount);
        return true;
    }

    function approveMax(address spender) external returns (bool) {
        return approve(spender, _totalSupply);
    }

    function transfer(address recipient, uint256 amount)
        external
        override
        returns (bool)
    {
        return _transferFrom(msg.sender, recipient, amount);
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external override returns (bool) {
        if (_allowances[sender][msg.sender] != _totalSupply) {
            _allowances[sender][msg.sender] = _allowances[sender][msg.sender]
                .sub(amount, "Insufficient Allowance");
        }

        return _transferFrom(sender, recipient, amount);
    }

    function _transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) internal returns (bool) {
        if (inSwap) {
            return _basicTransfer(sender, recipient, amount);
        }

        if (shouldSwapBack()) {
            swapBack();
        }
        if (shouldAutoBuyback()) {
            triggerAutoBuyback();
        }

        _balances[sender] = _balances[sender].sub(
            amount,
            "Insufficient Balance"
        );

        uint256 amountReceived = shouldTakeFee(sender)
            ? takeFee(sender, recipient, amount)
            : amount;

        _balances[recipient] = _balances[recipient].add(amountReceived);

        if (!isDividendExempt[sender]) {
            try distributor.setShare(sender, _balances[sender]) {} catch {}
        }
        if (!isDividendExempt[recipient]) {
            try
                distributor.setShare(recipient, _balances[recipient])
            {} catch {}
        }

        try distributor.process(distributorGas) {} catch {}

        emit Transfer(sender, recipient, amountReceived);
        return true;
    }

    function _basicTransfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(
            amount,
            "Insufficient Balance"
        );
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }

    function shouldTakeFee(address sender) internal view returns (bool) {
        return !isFeeExempt[sender];
    }

    function getTotalFee(bool selling) public view returns (uint256) {
        if (selling) {
            return getMultipliedFee();
        }
        return totalFee;
    }

    function getMultipliedFee() public view returns (uint256) {
        if (
            buybackMultiplierTriggeredAt.add(buybackMultiplierLength) >
            block.timestamp
        ) {
            uint256 remainingTime = buybackMultiplierTriggeredAt
                .add(buybackMultiplierLength)
                .sub(block.timestamp);
            uint256 feeIncrease = totalFee
                .mul(buybackMultiplierNumerator)
                .div(buybackMultiplierDenominator)
                .sub(totalFee);
            return
                totalFee.add(
                    feeIncrease.mul(remainingTime).div(buybackMultiplierLength)
                );
        }
        return totalFee;
    }

    function takeFee(
        address sender,
        address receiver,
        uint256 amount
    ) internal returns (uint256) {
        uint256 feeAmount = amount.mul(getTotalFee(receiver == pair)).div(
            feeDenominator
        );

        _balances[address(this)] = _balances[address(this)].add(feeAmount);
        emit Transfer(sender, address(this), feeAmount);

        return amount.sub(feeAmount);
    }

    function shouldSwapBack() internal view returns (bool) {
        return
            msg.sender != pair &&
            !inSwap &&
            swapEnabled &&
            _balances[address(this)] >= swapThreshold;
    }

    function swapBack() internal swapping {
        uint256 dynamicLiquidityFee = isOverLiquified(
            targetLiquidity,
            targetLiquidityDenominator
        )
            ? 0
            : liquidityFee;
        uint256 amountToLiquify = swapThreshold
            .mul(dynamicLiquidityFee)
            .div(totalFee)
            .div(2);
        uint256 amountToSwap = swapThreshold.sub(amountToLiquify);

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.WETH();
        uint256 balanceBefore = address(this).balance;

        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            amountToSwap,
            0,
            path,
            address(this),
            block.timestamp
        );

        uint256 amountBNB = address(this).balance.sub(balanceBefore);

        uint256 totalBNBFee = totalFee.sub(dynamicLiquidityFee.div(2));

        uint256 amountBNBLiquidity = amountBNB
            .mul(dynamicLiquidityFee)
            .div(totalBNBFee)
            .div(2);
        uint256 amountBNBReflection = amountBNB.mul(reflectionFee).div(
            totalBNBFee
        );
        uint256 amountBNBMarketing = amountBNB.mul(marketingFee).div(
            totalBNBFee
        );

        try distributor.deposit{ value: amountBNBReflection }() {} catch {}
        payable(marketingFeeReceiver).transfer(amountBNBMarketing);

        if (amountToLiquify > 0) {
            router.addLiquidityETH{ value: amountBNBLiquidity }(
                address(this),
                amountToLiquify,
                0,
                0,
                autoLiquidityReceiver,
                block.timestamp
            );
            emit AutoLiquify(amountBNBLiquidity, amountToLiquify);
        }
    }

    function shouldAutoBuyback() internal view returns (bool) {
        return
            msg.sender != pair &&
            !inSwap &&
            autoBuybackEnabled &&
            autoBuybackBlockLast + autoBuybackBlockPeriod <= block.number && // After N blocks from last buyback
            address(this).balance >= autoBuybackAmount;
    }

    function triggerZeusBuyback(uint256 amount, bool triggerBuybackMultiplier)
        external
        authorized
    {
        buyTokens(amount, DEAD);
        if (triggerBuybackMultiplier) {
            buybackMultiplierTriggeredAt = block.timestamp;
            emit BuybackMultiplierActive(buybackMultiplierLength);
        }
    }

    function clearBuybackMultiplier() external authorized {
        buybackMultiplierTriggeredAt = 0;
    }

    function triggerAutoBuyback() internal {
        buyTokens(autoBuybackAmount, DEAD);
        autoBuybackBlockLast = block.number;
        autoBuybackAccumulator = autoBuybackAccumulator.add(autoBuybackAmount);
        if (autoBuybackAccumulator > autoBuybackCap) {
            autoBuybackEnabled = false;
        }
    }

    function buyTokens(uint256 amount, address to) internal swapping {
        address[] memory path = new address[](2);
        path[0] = router.WETH();
        path[1] = address(this);

        router.swapExactETHForTokensSupportingFeeOnTransferTokens{
            value: amount
        }(0, path, to, block.timestamp);
    }

    function setAutoBuybackSettings(
        bool _enabled,
        uint256 _cap,
        uint256 _amount,
        uint256 _period
    ) external authorized {
        autoBuybackEnabled = _enabled;
        autoBuybackCap = _cap;
        autoBuybackAccumulator = 0;
        autoBuybackAmount = _amount;
        autoBuybackBlockPeriod = _period;
        autoBuybackBlockLast = block.number;
    }

    function setBuybackMultiplierSettings(
        uint256 numerator,
        uint256 denominator,
        uint256 length
    ) external authorized {
        require(numerator / denominator <= 2 && numerator > denominator);
        buybackMultiplierNumerator = numerator;
        buybackMultiplierDenominator = denominator;
        buybackMultiplierLength = length;
    }

    function setIsDividendExempt(address holder, bool exempt)
        external
        authorized
    {
        require(holder != address(this) && holder != pair);
        isDividendExempt[holder] = exempt;
        if (exempt) {
            distributor.setShare(holder, 0);
        } else {
            distributor.setShare(holder, _balances[holder]);
        }
    }

    function setIsFeeExempt(address holder, bool exempt) external authorized {
        isFeeExempt[holder] = exempt;
    }

    function setBuyBacker(address acc, bool add) external authorized {
        buyBacker[acc] = add;
    }

    function setFees(
        uint256 _liquidityFee,
        uint256 _buybackFee,
        uint256 _reflectionFee,
        uint256 _marketingFee,
        uint256 _feeDenominator
    ) public authorized {
        _setFees(
            _liquidityFee,
            _buybackFee,
            _reflectionFee,
            _marketingFee,
            _feeDenominator
        );
    }

    function _setFees(
        uint256 _liquidityFee,
        uint256 _buybackFee,
        uint256 _reflectionFee,
        uint256 _marketingFee,
        uint256 _feeDenominator
    ) internal {
        liquidityFee = _liquidityFee;
        buybackFee = _buybackFee;
        reflectionFee = _reflectionFee;
        marketingFee = _marketingFee;
        totalFee = _liquidityFee.add(_buybackFee).add(_reflectionFee).add(
            _marketingFee
        );
        feeDenominator = _feeDenominator;
        require(
            totalFee < feeDenominator / 4,
            "Total fee should not be greater than 1/4 of fee denominator"
        );
    }

    function setFeeReceivers(
        address _autoLiquidityReceiver,
        address _marketingFeeReceiver
    ) external authorized {
        autoLiquidityReceiver = _autoLiquidityReceiver;
        marketingFeeReceiver = _marketingFeeReceiver;
    }

    function setSwapBackSettings(bool _enabled, uint256 _amount)
        external
        authorized
    {
        swapEnabled = _enabled;
        swapThreshold = _amount;
    }

    function setTargetLiquidity(uint256 _target, uint256 _denominator)
        external
        authorized
    {
        targetLiquidity = _target;
        targetLiquidityDenominator = _denominator;
    }

    function setDistributionCriteria(
        uint256 _minPeriod,
        uint256 _minDistribution
    ) external authorized {
        distributor.setDistributionCriteria(_minPeriod, _minDistribution);
    }

    function setDistributorSettings(uint256 gas) external authorized {
        require(gas < 750000, "Gas must be lower than 750000");
        distributorGas = gas;
    }

    function getCirculatingSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(ZERO));
    }

    function getLiquidityBacking(uint256 accuracy)
        public
        view
        returns (uint256)
    {
        return accuracy.mul(balanceOf(pair).mul(2)).div(getCirculatingSupply());
    }

    function isOverLiquified(uint256 target, uint256 accuracy)
        public
        view
        returns (bool)
    {
        return getLiquidityBacking(accuracy) > target;
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"string","name":"name_","type":"string"},{"internalType":"string","name":"symbol_","type":"string"},{"internalType":"uint256","name":"totalSupply_","type":"uint256"},{"internalType":"address","name":"rewardToken_","type":"address"},{"internalType":"address","name":"router_","type":"address"},{"internalType":"uint256[5]","name":"feeSettings_","type":"uint256[5]"},{"internalType":"address","name":"serviceFeeReceiver_","type":"address"},{"internalType":"uint256","name":"serviceFee_","type":"uint256"}],"stateMutability":"payable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountBNB","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amountBOG","type":"uint256"}],"name":"AutoLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"duration","type":"uint256"}],"name":"BuybackMultiplierActive","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"enum TokenType","name":"tokenType","type":"uint8"},{"indexed":false,"internalType":"uint256","name":"version","type":"uint256"}],"name":"TokenCreated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"VERSION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"approveMax","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"adr","type":"address"}],"name":"authorize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"autoBuybackAccumulator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoBuybackAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoBuybackBlockLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoBuybackBlockPeriod","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoBuybackCap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoBuybackEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"autoLiquidityReceiver","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"buyBacker","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackMultiplierDenominator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackMultiplierLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackMultiplierNumerator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackMultiplierTriggeredAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"clearBuybackMultiplier","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"distributor","outputs":[{"internalType":"contract DividendDistributor","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"distributorGas","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeDenominator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getCirculatingSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"accuracy","type":"uint256"}],"name":"getLiquidityBacking","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMultipliedFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"selling","type":"bool"}],"name":"getTotalFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"adr","type":"address"}],"name":"isAuthorized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isDividendExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isFeeExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"target","type":"uint256"},{"internalType":"uint256","name":"accuracy","type":"uint256"}],"name":"isOverLiquified","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingFeeReceiver","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"reflectionFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"},{"internalType":"uint256","name":"_cap","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_period","type":"uint256"}],"name":"setAutoBuybackSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"acc","type":"address"},{"internalType":"bool","name":"add","type":"bool"}],"name":"setBuyBacker","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"numerator","type":"uint256"},{"internalType":"uint256","name":"denominator","type":"uint256"},{"internalType":"uint256","name":"length","type":"uint256"}],"name":"setBuybackMultiplierSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minPeriod","type":"uint256"},{"internalType":"uint256","name":"_minDistribution","type":"uint256"}],"name":"setDistributionCriteria","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"gas","type":"uint256"}],"name":"setDistributorSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_autoLiquidityReceiver","type":"address"},{"internalType":"address","name":"_marketingFeeReceiver","type":"address"}],"name":"setFeeReceivers","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_buybackFee","type":"uint256"},{"internalType":"uint256","name":"_reflectionFee","type":"uint256"},{"internalType":"uint256","name":"_marketingFee","type":"uint256"},{"internalType":"uint256","name":"_feeDenominator","type":"uint256"}],"name":"setFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsDividendExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsFeeExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"setSwapBackSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_target","type":"uint256"},{"internalType":"uint256","name":"_denominator","type":"uint256"}],"name":"setTargetLiquidity","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"targetLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"targetLiquidityDenominator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"adr","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bool","name":"triggerBuybackMultiplier","type":"bool"}],"name":"triggerZeusBuyback","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"adr","type":"address"}],"name":"unauthorize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

Deployed Bytecode

0x6080604052600436106103c75760003560e01c806370a08231116101f2578063d51ed1c81161010d578063f1f3bca3116100a0578063f7c618c11161006f578063f7c618c114610b07578063f887ea4014610b27578063fe9fbb8014610b47578063ffa1ad7414610b6757600080fd5b8063f1f3bca314610a87578063f2fde38b14610aa7578063f5cfec0a14610ac7578063f708a64f14610ae757600080fd5b8063e96fada2116100dc578063e96fada214610a01578063ecbf666f14610a21578063eff0dc2214610a37578063f0b37c0414610a6757600080fd5b8063d51ed1c814610966578063d806d12f14610986578063dd62ed3e1461099b578063df20fd49146109e157600080fd5b8063a4b45c0011610185578063b6a5d7de11610154578063b6a5d7de146108f0578063b91854f414610910578063bfe1092814610926578063ca33e64c1461094657600080fd5b8063a4b45c0014610863578063a8aa1b3114610883578063a9059cbb146108bb578063b210b06d146108db57600080fd5b806392258ec8116101c157806392258ec81461080257806395d89b411461081857806398118cb41461082d5780639d1944f51461084357600080fd5b806370a082311461078b57806383ad7994146107c05780638ab6ffc7146107d6578063921250d1146107ec57600080fd5b80632d48e896116102e2578063571ac8b011610275578063658d4b7f11610244578063658d4b7f146107255780636b67c4df146107455780636ddd17131461075b5780636e78eb491461077557600080fd5b8063571ac8b0146106c3578063591cf08d146106e35780635a53c1fb146106f957806360e719621461070f57600080fd5b80633bb8a8d4116102b15780633bb8a8d4146106335780633f4218e01461064d5780634355855a1461067d5780634896a632146106ad57600080fd5b80632d48e896146105b25780632f54bf6e146105d2578063313ce567146106015780633b2d081c1461061d57600080fd5b8063180b0d7e1161035a578063201e799111610329578063201e79911461053d5780632375ce401461055d57806323b872dd1461057d5780632b112e491461059d57600080fd5b8063180b0d7e146104e657806318160ddd146104fc57806319be947b146105115780631df4ccfc1461052757600080fd5b8063095ea7b311610396578063095ea7b3146104605780631023d5d4146104905780631161ae39146104a657806317d43583146104c657600080fd5b80630445b667146103d3578063048c7baf146103fc57806304a66b481461041e57806306fdde031461043e57600080fd5b366103ce57005b600080fd5b3480156103df57600080fd5b506103e9601f5481565b6040519081526020015b60405180910390f35b34801561040857600080fd5b5061041c61041736600461227a565b610b7c565b005b34801561042a57600080fd5b5061041c610439366004612365565b610bd3565b34801561044a57600080fd5b50610453610c0c565b6040516103f39190612417565b34801561046c57600080fd5b5061048061047b36600461221a565b610c9e565b60405190151581526020016103f3565b34801561049c57600080fd5b506103e960155481565b3480156104b257600080fd5b506104806104c13660046122ec565b610d0a565b3480156104d257600080fd5b5061041c6104e13660046121e6565b610d1e565b3480156104f257600080fd5b506103e9600f5481565b34801561050857600080fd5b506004546103e9565b34801561051d57600080fd5b506103e960145481565b34801561053357600080fd5b506103e9600e5481565b34801561054957600080fd5b5061041c6105583660046122ec565b610d6e565b34801561056957600080fd5b5061041c61057836600461230d565b610d9e565b34801561058957600080fd5b506104806105983660046121a6565b610df3565b3480156105a957600080fd5b506103e9610eb7565b3480156105be57600080fd5b5061041c6105cd3660046122ec565b610f27565b3480156105de57600080fd5b506104806105ed366004612136565b6000546001600160a01b0391821691161490565b34801561060d57600080fd5b50604051600981526020016103f3565b34801561062957600080fd5b506103e9600b5481565b34801561063f57600080fd5b506016546104809060ff1681565b34801561065957600080fd5b50610480610668366004612136565b60236020526000908152604090205460ff1681565b34801561068957600080fd5b50610480610698366004612136565b60246020526000908152604090205460ff1681565b3480156106b957600080fd5b506103e960195481565b3480156106cf57600080fd5b506104806106de366004612136565b610fb6565b3480156106ef57600080fd5b506103e960175481565b34801561070557600080fd5b506103e9601a5481565b34801561071b57600080fd5b506103e9601d5481565b34801561073157600080fd5b5061041c6107403660046121e6565b610fca565b34801561075157600080fd5b506103e9600d5481565b34801561076757600080fd5b50601e546104809060ff1681565b34801561078157600080fd5b506103e960185481565b34801561079757600080fd5b506103e96107a6366004612136565b6001600160a01b0316600090815260208052604090205490565b3480156107cc57600080fd5b506103e9600c5481565b3480156107e257600080fd5b506103e960115481565b3480156107f857600080fd5b506103e960125481565b34801561080e57600080fd5b506103e960105481565b34801561082457600080fd5b5061045361101a565b34801561083957600080fd5b506103e9600a5481565b34801561084f57600080fd5b5061041c61085e3660046122b2565b611029565b34801561086f57600080fd5b5061041c61087e36600461216e565b6110a5565b34801561088f57600080fd5b506007546108a3906001600160a01b031681565b6040516001600160a01b0390911681526020016103f3565b3480156108c757600080fd5b506104806108d636600461221a565b6110f8565b3480156108e757600080fd5b5061041c611105565b3480156108fc57600080fd5b5061041c61090b366004612136565b611131565b34801561091c57600080fd5b506103e9601b5481565b34801561093257600080fd5b50601c546108a3906001600160a01b031681565b34801561095257600080fd5b506008546108a3906001600160a01b031681565b34801561097257600080fd5b506103e96109813660046122b2565b611182565b34801561099257600080fd5b506103e96111c5565b3480156109a757600080fd5b506103e96109b636600461216e565b6001600160a01b03918216600090815260216020908152604080832093909416825291909152205490565b3480156109ed57600080fd5b5061041c6109fc36600461225f565b61125e565b348015610a0d57600080fd5b506009546108a3906001600160a01b031681565b348015610a2d57600080fd5b506103e960135481565b348015610a4357600080fd5b50610480610a52366004612136565b60226020526000908152604090205460ff1681565b348015610a7357600080fd5b5061041c610a82366004612136565b61129a565b348015610a9357600080fd5b506103e9610aa2366004612245565b6112e5565b348015610ab357600080fd5b5061041c610ac2366004612136565b6112fd565b348015610ad357600080fd5b5061041c610ae23660046122ca565b611393565b348015610af357600080fd5b5061041c610b023660046121e6565b611409565b348015610b1357600080fd5b506005546108a3906001600160a01b031681565b348015610b3357600080fd5b506006546108a3906001600160a01b031681565b348015610b5357600080fd5b50610480610b62366004612136565b61150c565b348015610b7357600080fd5b506103e9600181565b610b853361150c565b610baa5760405162461bcd60e51b8152600401610ba19061248a565b60405180910390fd5b6016805460ff1916941515949094179093556017919091556000601855601955601a5543601b55565b610bdc3361150c565b610bf85760405162461bcd60e51b8152600401610ba19061248a565b610c058585858585611536565b5050505050565b606060028054610c1b90612559565b80601f0160208091040260200160405190810160405280929190818152602001828054610c4790612559565b8015610c945780601f10610c6957610100808354040283529160200191610c94565b820191906000526020600020905b815481529060010190602001808311610c7757829003601f168201915b5050505050905090565b3360008181526021602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610cf99086815260200190565b60405180910390a350600192915050565b600082610d1683611182565b119392505050565b610d273361150c565b610d435760405162461bcd60e51b8152600401610ba19061248a565b6001600160a01b03919091166000908152602260205260409020805460ff1916911515919091179055565b610d773361150c565b610d935760405162461bcd60e51b8152600401610ba19061248a565b601091909155601155565b610da73361150c565b610dc35760405162461bcd60e51b8152600401610ba19061248a565b6002610dcf8385612503565b11158015610ddc57508183115b610de557600080fd5b601292909255601355601555565b6004546001600160a01b0384166000908152602160209081526040808320338452909152812054909114610ea2576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387166000908152602182528381203382529091529190912054610e7d9184906115e9565b6001600160a01b03851660009081526021602090815260408083203384529091529020555b610ead848484611615565b90505b9392505050565b602080527f29ab76e7ca72530a8284597fb76b039d796325740b21528d71ade454c6f2dbe95461dead60009081527fcbaad361c71be11fa6bdbe0e740c6259be964b32182da2da47b54472477c6a17546004549192610f22929091610f1c91906118ff565b906118ff565b905090565b610f303361150c565b610f4c5760405162461bcd60e51b8152600401610ba19061248a565b601c546040516316a4744b60e11b815260048101849052602481018390526001600160a01b0390911690632d48e896906044015b600060405180830381600087803b158015610f9a57600080fd5b505af1158015610fae573d6000803e3d6000fd5b505050505050565b6000610fc482600454610c9e565b92915050565b610fd33361150c565b610fef5760405162461bcd60e51b8152600401610ba19061248a565b6001600160a01b03919091166000908152602360205260409020805460ff1916911515919091179055565b606060038054610c1b90612559565b6110323361150c565b61104e5760405162461bcd60e51b8152600401610ba19061248a565b620b71b081106110a05760405162461bcd60e51b815260206004820152601d60248201527f476173206d757374206265206c6f776572207468616e203735303030300000006044820152606401610ba1565b601d55565b6110ae3361150c565b6110ca5760405162461bcd60e51b8152600401610ba19061248a565b600880546001600160a01b039384166001600160a01b03199182161790915560098054929093169116179055565b6000610eb0338484611615565b61110e3361150c565b61112a5760405162461bcd60e51b8152600401610ba19061248a565b6000601455565b6000546001600160a01b0316331461115b5760405162461bcd60e51b8152600401610ba19061246a565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b6000610fc461118f610eb7565b6007546001600160a01b031660009081526020805260409020546111bf906111b890600261190b565b859061190b565b90611917565b6000426111df60155460145461152a90919063ffffffff16565b111561125757600061120242610f1c60155460145461152a90919063ffffffff16565b90506000611229600e54610f1c6013546111bf601254600e5461190b90919063ffffffff16565b90506112506112476015546111bf858561190b90919063ffffffff16565b600e549061152a565b9250505090565b50600e5490565b6112673361150c565b6112835760405162461bcd60e51b8152600401610ba19061248a565b601e805460ff191692151592909217909155601f55565b6000546001600160a01b031633146112c45760405162461bcd60e51b8152600401610ba19061246a565b6001600160a01b03166000908152600160205260409020805460ff19169055565b600081156112f557610fc46111c5565b5050600e5490565b6000546001600160a01b031633146113275760405162461bcd60e51b8152600401610ba19061246a565b600080546001600160a01b0319166001600160a01b038316908117825580825260016020818152604093849020805460ff191690921790915591519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc686163910160405180910390a150565b61139c3361150c565b6113b85760405162461bcd60e51b8152600401610ba19061248a565b6113c48261dead611923565b801561140557426014556015546040519081527f39d2389ec5c1fa77b2c0d374bc61b6d7bd97ccba280fcdeb4e9c7644898d7c3a9060200160405180910390a15b5050565b6114123361150c565b61142e5760405162461bcd60e51b8152600401610ba19061248a565b6001600160a01b038216301480159061145557506007546001600160a01b03838116911614155b61145e57600080fd5b6001600160a01b0382166000908152602460205260409020805460ff191682158015919091179091556114c457601c54604051630a5b654b60e11b81526001600160a01b03848116600483015260006024830152909116906314b6ca9690604401610f80565b601c546001600160a01b03838116600081815260208052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401610f80565b6001600160a01b031660009081526001602052604090205460ff1690565b6000610eb082846124eb565b600a859055600b849055600c839055600d8290556115608261155a8581898961152a565b9061152a565b600e55600f819055611573600482612503565b600e5410610c055760405162461bcd60e51b815260206004820152603b60248201527f546f74616c206665652073686f756c64206e6f7420626520677265617465722060448201527f7468616e20312f34206f66206665652064656e6f6d696e61746f7200000000006064820152608401610ba1565b6000818484111561160d5760405162461bcd60e51b8152600401610ba19190612417565b505050900390565b60255460009060ff16156116355761162e848484611ab7565b9050610eb0565b61163d611b92565b1561164a5761164a611be0565b611652611fd8565b1561165f5761165f612033565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038716600090815290805291909120546116af9184906115e9565b6001600160a01b03851660009081526020808052604080832093909355602390529081205460ff16156116e257826116ed565b6116ed85858561206f565b6001600160a01b0385166000908152602080526040902054909150611712908261152a565b6001600160a01b038086166000908152602080805260408083209490945591881681526024909152205460ff166117b357601c546001600160a01b03868116600081815260208052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401600060405180830381600087803b1580156117a057600080fd5b505af19250505080156117b1575060015b505b6001600160a01b03841660009081526024602052604090205460ff1661184357601c546001600160a01b03858116600081815260208052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401600060405180830381600087803b15801561183057600080fd5b505af1925050508015611841575060015b505b601c54601d546040516001624d3b8760e01b031981526001600160a01b039092169163ffb2c4799161187b9160040190815260200190565b600060405180830381600087803b15801561189557600080fd5b505af19250505080156118a6575060015b50836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516118ec91815260200190565b60405180910390a3506001949350505050565b6000610eb08284612542565b6000610eb08284612523565b6000610eb08284612503565b6025805460ff191660011790556040805160028082526060820183526000926020830190803683375050600654604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b15801561199557600080fd5b505afa1580156119a9573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119cd9190612152565b816000815181106119ee57634e487b7160e01b600052603260045260246000fd5b60200260200101906001600160a01b031690816001600160a01b0316815250503081600181518110611a3057634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201015260065460405163b6f9de9560e01b815291169063b6f9de95908590611a76906000908690889042906004016123e2565b6000604051808303818588803b158015611a8f57600080fd5b505af1158015611aa3573d6000803e3d6000fd5b50506025805460ff19169055505050505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038616600090815290805291822054611b069184906115e9565b6001600160a01b0380861660009081526020805260408082209390935590851681522054611b34908361152a565b6001600160a01b038481166000818152602080805260409182902094909455518581529092918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35060019392505050565b6007546000906001600160a01b03163314801590611bb3575060255460ff16155b8015611bc15750601e5460ff165b8015610f22575050601f54306000908152602080526040902054101590565b6025805460ff19166001179055601054601154600091611bff91610d0a565b611c0b57600a54611c0e565b60005b90506000611c3260026111bf600e546111bf86601f5461190b90919063ffffffff16565b90506000611c4b82601f546118ff90919063ffffffff16565b60408051600280825260608201835292935060009290916020830190803683370190505090503081600081518110611c9357634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015611ce757600080fd5b505afa158015611cfb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d1f9190612152565b81600181518110611d4057634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201015260065460405163791ac94760e01b81524792919091169063791ac94790611d8a9086906000908790309042906004016124af565b600060405180830381600087803b158015611da457600080fd5b505af1158015611db8573d6000803e3d6000fd5b505050506000611dd182476118ff90919063ffffffff16565b90506000611dec611de3886002611917565b600e54906118ff565b90506000611e0160026111bf8481878d61190b565b90506000611e1e836111bf600c548761190b90919063ffffffff16565b90506000611e3b846111bf600d548861190b90919063ffffffff16565b9050601c60009054906101000a90046001600160a01b03166001600160a01b031663d0e30db0836040518263ffffffff1660e01b81526004016000604051808303818588803b158015611e8d57600080fd5b505af193505050508015611e9f575060015b506009546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015611eda573d6000803e3d6000fd5b508815611fc25760065460085460405163f305d71960e01b8152306004820152602481018c905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990859060c4016060604051808303818588803b158015611f4c57600080fd5b505af1158015611f60573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611f859190612338565b505060408051858152602081018c90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b50506025805460ff191690555050505050505050565b6007546000906001600160a01b03163314801590611ff9575060255460ff16155b8015612007575060165460ff165b8015612022575043601a54601b5461201f91906124eb565b11155b8015610f2257505060195447101590565b61204160195461dead611923565b43601b556019546018546120549161152a565b6018819055601754101561206d576016805460ff191690555b565b600f5460075460009182916120a191906111bf9061209a906001600160a01b038981169116146112e5565b869061190b565b3060009081526020805260409020549091506120bd908261152a565b3060008181526020808052604091829020939093555183815290916001600160a01b038816917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a361211883826118ff565b95945050505050565b8035801515811461213157600080fd5b919050565b600060208284031215612147578081fd5b8135610eb0816125aa565b600060208284031215612163578081fd5b8151610eb0816125aa565b60008060408385031215612180578081fd5b823561218b816125aa565b9150602083013561219b816125aa565b809150509250929050565b6000806000606084860312156121ba578081fd5b83356121c5816125aa565b925060208401356121d5816125aa565b929592945050506040919091013590565b600080604083850312156121f8578182fd5b8235612203816125aa565b915061221160208401612121565b90509250929050565b6000806040838503121561222c578182fd5b8235612237816125aa565b946020939093013593505050565b600060208284031215612256578081fd5b610eb082612121565b60008060408385031215612271578182fd5b61223783612121565b6000806000806080858703121561228f578081fd5b61229885612121565b966020860135965060408601359560600135945092505050565b6000602082840312156122c3578081fd5b5035919050565b600080604083850312156122dc578182fd5b8235915061221160208401612121565b600080604083850312156122fe578182fd5b50508035926020909101359150565b600080600060608486031215612321578283fd5b505081359360208301359350604090920135919050565b60008060006060848603121561234c578283fd5b8351925060208401519150604084015190509250925092565b600080600080600060a0868803121561237c578283fd5b505083359560208501359550604085013594606081013594506080013592509050565b6000815180845260208085019450808401835b838110156123d75781516001600160a01b0316875295820195908201906001016123b2565b509495945050505050565b8481526080602082015260006123fb608083018661239f565b6001600160a01b03949094166040830152506060015292915050565b6000602080835283518082850152825b8181101561244357858101830151858201604001528201612427565b818111156124545783604083870101525b50601f01601f1916929092016040019392505050565b60208082526006908201526510a7aba722a960d11b604082015260600190565b6020808252600b908201526a085055551213d49256915160aa1b604082015260600190565b85815284602082015260a0604082015260006124ce60a083018661239f565b6001600160a01b0394909416606083015250608001529392505050565b600082198211156124fe576124fe612594565b500190565b60008261251e57634e487b7160e01b81526012600452602481fd5b500490565b600081600019048311821515161561253d5761253d612594565b500290565b60008282101561255457612554612594565b500390565b600181811c9082168061256d57607f821691505b6020821081141561258e57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b03811681146125bf57600080fd5b5056fea264697066735822122035e729ee0545cffcb92ac71f8f53f9c01f1323ced0bf42146eaafe20fdb89ca164736f6c63430008040033

Deployed Bytecode Sourcemap

27842:17028:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29426:28;;;;;;;;;;;;;;;;;;;10672:25:1;;;10660:2;10645:18;29426:28:0;;;;;;;;40795:402;;;;;;;;;;-1:-1:-1;40795:402:0;;;;;:::i;:::-;;:::i;:::-;;42211:382;;;;;;;;;;-1:-1:-1;42211:382:0;;;;;:::i;:::-;;:::i;32740:94::-;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;33165:248::-;;;;;;;;;;-1:-1:-1;33165:248:0;;;;;:::i;:::-;;:::i;:::-;;;7446:14:1;;7439:22;7421:41;;7409:2;7394:18;33165:248:0;7376:92:1;28998:38:0;;;;;;;;;;;;;;;;44685:182;;;;;;;;;;-1:-1:-1;44685:182:0;;;;;:::i;:::-;;:::i;42099:104::-;;;;;;;;;;-1:-1:-1;42099:104:0;;;;;:::i;:::-;;:::i;28644:29::-;;;;;;;;;;;;;;;;32422:102;;;;;;;;;;-1:-1:-1;32504:12:0;;32422:102;;28948:43;;;;;;;;;;;;;;;;28614:23;;;;;;;;;;;;;;;;43721:206;;;;;;;;;;-1:-1:-1;43721:206:0;;;;;:::i;:::-;;:::i;41205:376::-;;;;;;;;;;-1:-1:-1;41205:376:0;;;;;:::i;:::-;;:::i;33742:419::-;;;;;;;;;;-1:-1:-1;33742:419:0;;;;;:::i;:::-;;:::i;44328:142::-;;;;;;;;;;;;;:::i;43935:208::-;;;;;;;;;;-1:-1:-1;43935:208:0;;;;;:::i;:::-;;:::i;19400:103::-;;;;;;;;;;-1:-1:-1;19400:103:0;;;;;:::i;:::-;19455:4;19490:5;-1:-1:-1;;;;;19479:16:0;;;19490:5;;19479:16;;19400:103;32532:94;;;;;;;;;;-1:-1:-1;32532:94:0;;28127:1;11690:36:1;;11678:2;11663:18;32532:94:0;11645:87:1;28465:25:0;;;;;;;;;;;;;;;;29065:30;;;;;;;;;;-1:-1:-1;29065:30:0;;;;;;;;29639:43;;;;;;;;;;-1:-1:-1;29639:43:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29689:48;;;;;;;;;;-1:-1:-1;29689:48:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29184:32;;;;;;;;;;;;;;;;33421:117;;;;;;;;;;-1:-1:-1;33421:117:0;;;;;:::i;:::-;;:::i;29104:29::-;;;;;;;;;;;;;;;;29223:37;;;;;;;;;;;;;;;;29358:29;;;;;;;;;;;;;;;;41971:120;;;;;;;;;;-1:-1:-1;41971:120:0;;;;;:::i;:::-;;:::i;28564:27::-;;;;;;;;;;;;;;;;29396:23;;;;;;;;;;-1:-1:-1;29396:23:0;;;;;;;;29140:37;;;;;;;;;;;;;;;;32842:119;;;;;;;;;;-1:-1:-1;32842:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;32935:18:0;32908:7;32935:18;;;:9;:18;;;;;;;32842:119;28513:28;;;;;;;;;;;;;;;;28752:41;;;;;;;;;;;;;;;;28818;;;;;;;;;;;;;;;;28700:30;;;;;;;;;;;;;;;;32634:98;;;;;;;;;;;;;:::i;28415:27::-;;;;;;;;;;;;;;;;44151:169;;;;;;;;;;-1:-1:-1;44151:169:0;;;;;:::i;:::-;;:::i;43273:253::-;;;;;;;;;;-1:-1:-1;43273:253:0;;;;;:::i;:::-;;:::i;28302:19::-;;;;;;;;;;-1:-1:-1;28302:19:0;;;;-1:-1:-1;;;;;28302:19:0;;;;;;-1:-1:-1;;;;;5843:32:1;;;5825:51;;5813:2;5798:18;28302:19:0;5780:102:1;33546:188:0;;;;;;;;;;-1:-1:-1;33546:188:0;;;;;:::i;:::-;;:::i;40008:105::-;;;;;;;;;;;;;:::i;19073:94::-;;;;;;;;;;-1:-1:-1;19073:94:0;;;;;:::i;:::-;;:::i;29267:35::-;;;;;;;;;;;;;;;;29311:38;;;;;;;;;;-1:-1:-1;29311:38:0;;;;-1:-1:-1;;;;;29311:38:0;;;28328:36;;;;;;;;;;-1:-1:-1;28328:36:0;;;;-1:-1:-1;;;;;28328:36:0;;;44478:199;;;;;;;;;;-1:-1:-1;44478:199:0;;;;;:::i;:::-;;:::i;36057:716::-;;;;;;;;;;;;;:::i;32969:188::-;;;;;;;;;;-1:-1:-1;32969:188:0;;;;;:::i;:::-;-1:-1:-1;;;;;33121:19:0;;;33089:7;33121:19;;;:11;:19;;;;;;;;:28;;;;;;;;;;;;;32969:188;43534:179;;;;;;;;;;-1:-1:-1;43534:179:0;;;;;:::i;:::-;;:::i;28371:35::-;;;;;;;;;;-1:-1:-1;28371:35:0;;;;-1:-1:-1;;;;;28371:35:0;;;28882:43;;;;;;;;;;;;;;;;29591:41;;;;;;;;;;-1:-1:-1;29591:41:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;19243:97;;;;;;;;;;-1:-1:-1;19243:97:0;;;;;:::i;:::-;;:::i;35875:174::-;;;;;;;;;;-1:-1:-1;35875:174:0;;;;;:::i;:::-;;:::i;19800:173::-;;;;;;;;;;-1:-1:-1;19800:173:0;;;;;:::i;:::-;;:::i;39659:341::-;;;;;;;;;;-1:-1:-1;39659:341:0;;;;;:::i;:::-;;:::i;41589:374::-;;;;;;;;;;-1:-1:-1;41589:374:0;;;;;:::i;:::-;;:::i;28230:26::-;;;;;;;;;;-1:-1:-1;28230:26:0;;;;-1:-1:-1;;;;;28230:26:0;;;28263:32;;;;;;;;;;-1:-1:-1;28263:32:0;;;;-1:-1:-1;;;;;28263:32:0;;;19574:107;;;;;;;;;;-1:-1:-1;19574:107:0;;;;;:::i;:::-;;:::i;27945:35::-;;;;;;;;;;;;27979:1;27945:35;;40795:402;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;;;;;;;;;40964:18:::1;:29:::0;;-1:-1:-1;;40964:29:0::1;::::0;::::1;;::::0;;;::::1;::::0;;;41004:14:::1;:21:::0;;;;-1:-1:-1;41036:22:0::1;:26:::0;41073:17:::1;:27:::0;41111:22:::1;:32:::0;41177:12:::1;41154:20;:35:::0;40795:402::o;42211:382::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;42425:160:::1;42448:13;42476:11;42502:14;42531:13;42559:15;42425:8;:160::i;:::-;42211:382:::0;;;;;:::o;32740:94::-;32788:13;32821:5;32814:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32740:94;:::o;33165:248::-;33301:10;33267:4;33289:23;;;:11;:23;;;;;;;;-1:-1:-1;;;;;33289:32:0;;;;;;;;;;:41;;;33346:37;33267:4;;33289:32;;33346:37;;;;33324:6;10672:25:1;;10660:2;10645:18;;10627:76;33346:37:0;;;;;;;;-1:-1:-1;33401:4:0;33165:248;;;;:::o;44685:182::-;44792:4;44853:6;44821:29;44841:8;44821:19;:29::i;:::-;:38;;44685:182;-1:-1:-1;;;44685:182:0:o;42099:104::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;42175:14:0;;;::::1;;::::0;;;:9:::1;:14;::::0;;;;:20;;-1:-1:-1;;42175:20:0::1;::::0;::::1;;::::0;;;::::1;::::0;;42099:104::o;43721:206::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;43842:15:::1;:25:::0;;;;43878:26:::1;:41:::0;43721:206::o;41205:376::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;41399:1:::1;41372:23;41384:11:::0;41372:9;:23:::1;:::i;:::-;:28;;:55;;;;;41416:11;41404:9;:23;41372:55;41364:64;;;::::0;::::1;;41439:26;:38:::0;;;;41488:28:::1;:42:::0;41541:23:::1;:32:::0;41205:376::o;33742:419::-;33932:12;;-1:-1:-1;;;;;33897:19:0;;33876:4;33897:19;;;:11;:19;;;;;;;;33917:10;33897:31;;;;;;;;33876:4;;33897:47;33893:201;;33995:87;;;;;;;;;;;-1:-1:-1;;;33995:87:0;;;;;;;;-1:-1:-1;;;;;33995:19:0;;-1:-1:-1;33995:19:0;;;:11;:19;;;;;34015:10;33995:31;;;;;;;;;;:87;;34049:6;;33995:53;:87::i;:::-;-1:-1:-1;;;;;33961:19:0;;;;;;:11;:19;;;;;;;;33981:10;33961:31;;;;;;;:121;33893:201;34113:40;34127:6;34135:9;34146:6;34113:13;:40::i;:::-;34106:47;;33742:419;;;;;;:::o;44328:142::-;32935:9;:18;;;;28029:6;44381:7;32935:18;;;;;44408:12;;44381:7;;44408:54;;32935:18;;44408:33;;:12;:16;:33::i;:::-;:37;;:54::i;:::-;44401:61;;44328:142;:::o;43935:208::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;44070:11:::1;::::0;:65:::1;::::0;-1:-1:-1;;;44070:65:0;;::::1;::::0;::::1;11469:25:1::0;;;11510:18;;;11503:34;;;-1:-1:-1;;;;;44070:11:0;;::::1;::::0;:35:::1;::::0;11442:18:1;;44070:65:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;43935:208:::0;;:::o;33421:117::-;33476:4;33500:30;33508:7;33517:12;;33500:7;:30::i;:::-;33493:37;33421:117;-1:-1:-1;;33421:117:0:o;41971:120::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;42055:19:0;;;::::1;;::::0;;;:11:::1;:19;::::0;;;;:28;;-1:-1:-1;;42055:28:0::1;::::0;::::1;;::::0;;;::::1;::::0;;41971:120::o;32634:98::-;32684:13;32717:7;32710:14;;;;;:::i;44151:169::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;44241:6:::1;44235:3;:12;44227:54;;;::::0;-1:-1:-1;;;44227:54:0;;9268:2:1;44227:54:0::1;::::0;::::1;9250:21:1::0;9307:2;9287:18;;;9280:30;9346:31;9326:18;;;9319:59;9395:18;;44227:54:0::1;9240:179:1::0;44227:54:0::1;44292:14;:20:::0;44151:169::o;43273:253::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;43417:21:::1;:46:::0;;-1:-1:-1;;;;;43417:46:0;;::::1;-1:-1:-1::0;;;;;;43417:46:0;;::::1;;::::0;;;43474:20:::1;:44:::0;;;;;::::1;::::0;::::1;;::::0;;43273:253::o;33546:188::-;33653:4;33682:44;33696:10;33708:9;33719:6;33682:13;:44::i;40008:105::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;40104:1:::1;40073:28;:32:::0;40008:105::o;19073:94::-;19455:4;19490:5;-1:-1:-1;;;;;19490:5:0;18779:10;19479:16;18763:38;;;;-1:-1:-1;;;18763:38:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;19133:19:0::1;;::::0;;;19155:4:::1;19133:19;::::0;;;;;;;:26;;-1:-1:-1;;19133:26:0::1;::::0;;::::1;::::0;;19073:94::o;44478:199::-;44573:7;44605:64;44646:22;:20;:22::i;:::-;44628:4;;-1:-1:-1;;;;;44628:4:0;32908:7;32935:18;;;:9;:18;;;;;;44605:36;;44618:22;;44638:1;44618:19;:22::i;:::-;44605:8;;:12;:36::i;:::-;:40;;:64::i;36057:716::-;36106:7;36217:15;36144:57;36177:23;;36144:28;;:32;;:57;;;;:::i;:::-;:88;36126:614;;;36259:21;36283:114;36381:15;36283:75;36334:23;;36283:28;;:50;;:75;;;;:::i;:114::-;36259:138;;36412:19;36434:142;36567:8;;36434:110;36515:28;;36434:58;36465:26;;36434:8;;:30;;:58;;;;:::i;:142::-;36412:164;;36615:113;36650:59;36685:23;;36650:30;36666:13;36650:11;:15;;:30;;;;:::i;:59::-;36615:8;;;:12;:113::i;:::-;36591:137;;;;36057:716;:::o;36126:614::-;-1:-1:-1;36757:8:0;;;36057:716::o;43534:179::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;43649:11:::1;:22:::0;;-1:-1:-1;;43649:22:0::1;::::0;::::1;;::::0;;;::::1;::::0;;;43682:13:::1;:23:::0;43534:179::o;19243:97::-;19455:4;19490:5;-1:-1:-1;;;;;19490:5:0;18779:10;19479:16;18763:38;;;;-1:-1:-1;;;18763:38:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;19305:19:0::1;19327:5;19305:19:::0;;;:14:::1;:19;::::0;;;;:27;;-1:-1:-1;;19305:27:0::1;::::0;;19243:97::o;35875:174::-;35931:7;35955;35951:65;;;35986:18;:16;:18::i;35951:65::-;-1:-1:-1;;36033:8:0;;;35875:174::o;19800:173::-;19455:4;19490:5;-1:-1:-1;;;;;19490:5:0;18779:10;19479:16;18763:38;;;;-1:-1:-1;;;18763:38:0;;;;;;;:::i;:::-;19876:5:::1;:11:::0;;-1:-1:-1;;;;;;19876:11:0::1;-1:-1:-1::0;;;;;19876:11:0;::::1;::::0;;::::1;::::0;;19898:19;;;-1:-1:-1;19898:19:0::1;::::0;;;;;;;;:26;;-1:-1:-1;;19898:26:0::1;::::0;;::::1;::::0;;;19940:25;;5825:51:1;;;19940:25:0::1;::::0;5798:18:1;19940:25:0::1;;;;;;;19800:173:::0;:::o;39659:341::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;39788:23:::1;39798:6;28029;39788:9;:23::i;:::-;39826:24;39822:171;;;39898:15;39867:28;:46:::0;39957:23:::1;::::0;39933:48:::1;::::0;10672:25:1;;;39933:48:0::1;::::0;10660:2:1;10645:18;39933:48:0::1;;;;;;;39822:171;39659:341:::0;;:::o;41589:374::-;18949:24;18962:10;18949:12;:24::i;:::-;18941:48;;;;-1:-1:-1;;;18941:48:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;41709:23:0;::::1;41727:4;41709:23;::::0;::::1;::::0;:41:::1;;-1:-1:-1::0;41746:4:0::1;::::0;-1:-1:-1;;;;;41736:14:0;;::::1;41746:4:::0;::::1;41736:14;;41709:41;41701:50;;;::::0;::::1;;-1:-1:-1::0;;;;;41762:24:0;::::1;;::::0;;;:16:::1;:24;::::0;;;;:33;;-1:-1:-1;;41762:33:0::1;::::0;::::1;::::0;::::1;::::0;;;::::1;::::0;;;41806:150:::1;;41833:11;::::0;:31:::1;::::0;-1:-1:-1;;;41833:31:0;;-1:-1:-1;;;;;6303:32:1;;;41833:31:0::1;::::0;::::1;6285:51:1::0;41833:11:0::1;6352:18:1::0;;;6345:34;41833:11:0;;::::1;::::0;:20:::1;::::0;6258:18:1;;41833:31:0::1;6240:145:1::0;41806:150:0::1;41897:11;::::0;-1:-1:-1;;;;;41926:17:0;;::::1;41897:11;41926:17:::0;;;:9:::1;:17:::0;;;;;;;;41897:47;;-1:-1:-1;;;41897:47:0;;::::1;::::0;::::1;6285:51:1::0;;;;6352:18;;;6345:34;41897:11:0;::::1;::::0;:20:::1;::::0;6258:18:1;;41897:47:0::1;6240:145:1::0;19574:107:0;-1:-1:-1;;;;;19654:19:0;19630:4;19654:19;;;:14;:19;;;;;;;;;19574:107::o;2837:98::-;2895:7;2922:5;2926:1;2922;:5;:::i;42601:664::-;42807:12;:28;;;42846:10;:24;;;42881:13;:30;;;42922:12;:28;;;42972:93;42937:13;42972:50;42897:14;42972:50;42822:13;42859:11;42972:17;:30::i;:::-;:34;;:50::i;:93::-;42961:8;:104;43076:14;:32;;;43152:18;43169:1;43093:15;43152:18;:::i;:::-;43141:8;;:29;43119:138;;;;-1:-1:-1;;;43119:138:0;;10300:2:1;43119:138:0;;;10282:21:1;10339:2;10319:18;;;10312:30;10378:34;10358:18;;;10351:62;10449:29;10429:18;;;10422:57;10496:19;;43119:138:0;10272:249:1;5116:240:0;5236:7;5297:12;5289:6;;;;5281:29;;;;-1:-1:-1;;;5281:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;5332:5:0;;;5116:240::o;34169:1167::-;34316:6;;34295:4;;34316:6;;34312:87;;;34346:41;34361:6;34369:9;34380:6;34346:14;:41::i;:::-;34339:48;;;;34312:87;34415:16;:14;:16::i;:::-;34411:59;;;34448:10;:8;:10::i;:::-;34484:19;:17;:19::i;:::-;34480:72;;;34520:20;:18;:20::i;:::-;34584:90;;;;;;;;;;;-1:-1:-1;;;34584:90:0;;;;;;;;-1:-1:-1;;;;;34584:17:0;;-1:-1:-1;34584:17:0;;;;;;;;;;;:90;;34620:6;;34584:21;:90::i;:::-;-1:-1:-1;;;;;34564:17:0;;;;;;:9;:17;;;;;;;:110;;;;35840:11;:19;;;;;;;;35839:20;34712:93;;34799:6;34712:93;;;34749:34;34757:6;34765:9;34776:6;34749:7;:34::i;:::-;-1:-1:-1;;;;;34841:20:0;;;;;;:9;:20;;;;;;34687:118;;-1:-1:-1;34841:40:0;;34687:118;34841:24;:40::i;:::-;-1:-1:-1;;;;;34818:20:0;;;;;;;:9;:20;;;;;;;:63;;;;34899:24;;;;;:16;:24;;;;;;;34894:120;;34944:11;;-1:-1:-1;;;;;34973:17:0;;;34944:11;34973:17;;;:9;:17;;;;;;;;34944:47;;-1:-1:-1;;;34944:47:0;;;;;6285:51:1;;;;6352:18;;;6345:34;34944:11:0;;;:20;;6258:18:1;;34944:47:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34940:63;;-1:-1:-1;;;;;35029:27:0;;;;;;:16;:27;;;;;;;;35024:159;;35094:11;;-1:-1:-1;;;;;35126:20:0;;;35094:11;35126:20;;;:9;:20;;;;;;;;35094:53;;-1:-1:-1;;;35094:53:0;;;;;6285:51:1;;;;6352:18;;;6345:34;35094:11:0;;;:20;;6258:18:1;;35094:53:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;35073:99;;35199:11;;35219:14;;35199:35;;-1:-1:-1;;;;;;35199:35:0;;-1:-1:-1;;;;;35199:11:0;;;;:19;;:35;;;;10672:25:1;;;10660:2;10645:18;;10627:76;35199:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;35195:51;35280:9;-1:-1:-1;;;;;35263:43:0;35272:6;-1:-1:-1;;;;;35263:43:0;;35291:14;35263:43;;;;10672:25:1;;10660:2;10645:18;;10627:76;35263:43:0;;;;;;;;-1:-1:-1;35324:4:0;;34169:1167;-1:-1:-1;;;;34169:1167:0:o;3218:98::-;3276:7;3303:5;3307:1;3303;:5;:::i;3575:98::-;3633:7;3660:5;3664:1;3660;:5;:::i;3974:98::-;4032:7;4059:5;4063:1;4059;:5;:::i;40456:331::-;29913:6;:13;;-1:-1:-1;;29913:13:0;29922:4;29913:13;;;40556:16:::1;::::0;;40570:1:::1;40556:16:::0;;;;;::::1;::::0;;-1:-1:-1;;40556:16:0::1;::::0;::::1;::::0;;::::1;::::0;::::1;-1:-1:-1::0;;40593:6:0::1;::::0;:13:::1;::::0;;-1:-1:-1;;;40593:13:0;;;;40532:40;;-1:-1:-1;;;;;;40593:6:0;;::::1;::::0;:11:::1;::::0;-1:-1:-1;40593:13:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;;;;:6;:13;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;40583:4;40588:1;40583:7;;;;;;-1:-1:-1::0;;;40583:7:0::1;;;;;;;;;;;;;;:23;-1:-1:-1::0;;;;;40583:23:0::1;;;-1:-1:-1::0;;;;;40583:23:0::1;;;::::0;::::1;40635:4;40617;40622:1;40617:7;;;;;;-1:-1:-1::0;;;40617:7:0::1;;;;;;;;;-1:-1:-1::0;;;;;40617:23:0;;::::1;:7;::::0;;::::1;::::0;;;;;:23;40653:6:::1;::::0;:126:::1;::::0;-1:-1:-1;;;40653:126:0;;:6;::::1;::::0;:57:::1;::::0;40732:6;;40653:126:::1;::::0;:6:::1;::::0;40753:4;;40759:2;;40763:15:::1;::::0;40653:126:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;29949:6:0;:14;;-1:-1:-1;;29949:14:0;;;-1:-1:-1;;;;;;40456:331:0:o;35344:401::-;35508:90;;;;;;;;;;;-1:-1:-1;;;35508:90:0;;;;;;;;-1:-1:-1;;;;;35508:17:0;;35471:4;35508:17;;;;;;;;;;:90;;35544:6;;35508:21;:90::i;:::-;-1:-1:-1;;;;;35488:17:0;;;;;;;:9;:17;;;;;;:110;;;;35632:20;;;;;;;:32;;35657:6;35632:24;:32::i;:::-;-1:-1:-1;;;;;35609:20:0;;;;;;;:9;:20;;;;;;;;:55;;;;35680:35;10672:25:1;;;35609:20:0;;35680:35;;;;;;10645:18:1;35680:35:0;;;;;;;-1:-1:-1;35733:4:0;35344:401;;;;;:::o;37219:222::-;37319:4;;37268;;-1:-1:-1;;;;;37319:4:0;37305:10;:18;;;;:42;;-1:-1:-1;37341:6:0;;;;37340:7;37305:42;:70;;;;-1:-1:-1;37364:11:0;;;;37305:70;:128;;;;-1:-1:-1;;37420:13:0;;37410:4;37392:24;;;;:9;:24;;;;;;:41;;;37219:222::o;37449:1847::-;29913:6;:13;;-1:-1:-1;;29913:13:0;29922:4;29913:13;;;37558:15:::1;::::0;37588:26:::1;::::0;29913:6;;37528:97:::1;::::0;:15:::1;:97::i;:::-;:142;;37658:12;;37528:142;;;37641:1;37528:142;37498:172;;37681:23;37707:101;37806:1;37707:80;37778:8;;37707:52;37739:19;37707:13;;:31;;:52;;;;:::i;:101::-;37681:127;;37819:20;37842:34;37860:15;37842:13;;:17;;:34;;;;:::i;:::-;37913:16;::::0;;37927:1:::1;37913:16:::0;;;;;::::1;::::0;;37819:57;;-1:-1:-1;37889:21:0::1;::::0;37913:16;;::::1;::::0;::::1;::::0;;::::1;::::0;::::1;;::::0;-1:-1:-1;37913:16:0::1;37889:40;;37958:4;37940;37945:1;37940:7;;;;;;-1:-1:-1::0;;;37940:7:0::1;;;;;;;;;-1:-1:-1::0;;;;;37940:23:0;;::::1;:7;::::0;;::::1;::::0;;;;;;:23;;;;37984:6:::1;::::0;:13:::1;::::0;;-1:-1:-1;;;37984:13:0;;;;:6;;;::::1;::::0;:11:::1;::::0;:13:::1;::::0;;::::1;::::0;37940:7;;37984:13;;;;;:6;:13;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37974:4;37979:1;37974:7;;;;;;-1:-1:-1::0;;;37974:7:0::1;;;;;;;;;-1:-1:-1::0;;;;;37974:23:0;;::::1;:7;::::0;;::::1;::::0;;;;;:23;38066:6:::1;::::0;:188:::1;::::0;-1:-1:-1;;;38066:188:0;;38032:21:::1;::::0;38066:6;;;::::1;::::0;:57:::1;::::0;:188:::1;::::0;38138:12;;38008:21:::1;::::0;38181:4;;38208::::1;::::0;38228:15:::1;::::0;38066:188:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;38267:17;38287:40;38313:13;38287:21;:25;;:40;;;;:::i;:::-;38267:60:::0;-1:-1:-1;38340:19:0::1;38362:40;38375:26;:19:::0;38399:1:::1;38375:23;:26::i;:::-;38362:8;::::0;;:12:::1;:40::i;:::-;38340:62:::0;-1:-1:-1;38415:26:0::1;38444:100;38542:1;38444:79;38340:62:::0;38444:79;:9;38472:19;38444:27:::1;:48::i;:100::-;38415:129;;38555:27;38585:69;38632:11;38585:28;38599:13;;38585:9;:13;;:28;;;;:::i;:69::-;38555:99;;38665:26;38694:68;38740:11;38694:27;38708:12;;38694:9;:13;;:27;;;;:::i;:68::-;38665:97;;38779:11;;;;;;;;;-1:-1:-1::0;;;;;38779:11:0::1;-1:-1:-1::0;;;;;38779:19:0::1;;38807;38779:51;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;38775:67:::0;38860:20:::1;::::0;38852:58:::1;::::0;-1:-1:-1;;;;;38860:20:0;;::::1;::::0;38852:58;::::1;;;::::0;38891:18;;38860:20:::1;38852:58:::0;38860:20;38852:58;38891:18;38860:20;38852:58;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;38927:19:0;;38923:366:::1;;38963:6;::::0;39139:21:::1;::::0;38963:246:::1;::::0;-1:-1:-1;;;38963:246:0;;39041:4:::1;38963:246;::::0;::::1;7010:34:1::0;7060:18;;;7053:34;;;38963:6:0::1;7103:18:1::0;;;7096:34;;;7146:18;;;7139:34;-1:-1:-1;;;;;39139:21:0;;::::1;7189:19:1::0;;;7182:44;39179:15:0::1;7242:19:1::0;;;7235:35;38963:6:0;::::1;::::0;:22:::1;::::0;38994:18;;6944:19:1;;38963:246:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;39229:48:0::1;::::0;;11469:25:1;;;11525:2;11510:18;;11503:34;;;39229:48:0::1;::::0;-1:-1:-1;11442:18:1;39229:48:0::1;;;;;;;38923:366;-1:-1:-1::0;;29949:6:0;:14;;-1:-1:-1;;29949:14:0;;;-1:-1:-1;;;;;;;;37449:1847:0:o;39304:347::-;39407:4;;39356;;-1:-1:-1;;;;;39407:4:0;39393:10;:18;;;;:42;;-1:-1:-1;39429:6:0;;;;39428:7;39393:42;:77;;;;-1:-1:-1;39452:18:0;;;;39393:77;:155;;;;;39536:12;39510:22;;39487:20;;:45;;;;:::i;:::-;:61;;39393:155;:250;;;;-1:-1:-1;;39626:17:0;;39601:21;:42;;;39304:347::o;40121:327::-;40171:34;40181:17;;28029:6;40171:9;:34::i;:::-;40239:12;40216:20;:35;40314:17;;40287:22;;:45;;:26;:45::i;:::-;40262:22;:70;;;40372:14;;-1:-1:-1;40343:98:0;;;40403:18;:26;;-1:-1:-1;;40403:26:0;;;40343:98;40121:327::o;36781:430::-;37000:14;;36975:4;;36900:7;;;;36940:85;;37000:14;36940:41;;36951:29;;-1:-1:-1;;;;;36963:16:0;;;36975:4;;36963:16;36951:11;:29::i;:::-;36940:6;;:10;:41::i;:85::-;37083:4;37065:24;;;;:9;:24;;;;;;36920:105;;-1:-1:-1;37065:39:0;;36920:105;37065:28;:39::i;:::-;37056:4;37038:24;;;;:9;:24;;;;;;;;:66;;;;37120:42;10672:25:1;;;37056:4:0;;-1:-1:-1;;;;;37120:42:0;;;;;10645:18:1;37120:42:0;;;;;;;37182:21;:6;37193:9;37182:10;:21::i;:::-;37175:28;36781:430;-1:-1:-1;;;;;36781:430:0:o;14:160:1:-;79:20;;135:13;;128:21;118:32;;108:2;;164:1;161;154:12;108:2;60:114;;;:::o;179:257::-;238:6;291:2;279:9;270:7;266:23;262:32;259:2;;;312:6;304;297:22;259:2;356:9;343:23;375:31;400:5;375:31;:::i;441:261::-;511:6;564:2;552:9;543:7;539:23;535:32;532:2;;;585:6;577;570:22;532:2;622:9;616:16;641:31;666:5;641:31;:::i;977:398::-;1045:6;1053;1106:2;1094:9;1085:7;1081:23;1077:32;1074:2;;;1127:6;1119;1112:22;1074:2;1171:9;1158:23;1190:31;1215:5;1190:31;:::i;:::-;1240:5;-1:-1:-1;1297:2:1;1282:18;;1269:32;1310:33;1269:32;1310:33;:::i;:::-;1362:7;1352:17;;;1064:311;;;;;:::o;1380:466::-;1457:6;1465;1473;1526:2;1514:9;1505:7;1501:23;1497:32;1494:2;;;1547:6;1539;1532:22;1494:2;1591:9;1578:23;1610:31;1635:5;1610:31;:::i;:::-;1660:5;-1:-1:-1;1717:2:1;1702:18;;1689:32;1730:33;1689:32;1730:33;:::i;:::-;1484:362;;1782:7;;-1:-1:-1;;;1836:2:1;1821:18;;;;1808:32;;1484:362::o;1851:325::-;1916:6;1924;1977:2;1965:9;1956:7;1952:23;1948:32;1945:2;;;1998:6;1990;1983:22;1945:2;2042:9;2029:23;2061:31;2086:5;2061:31;:::i;:::-;2111:5;-1:-1:-1;2135:35:1;2166:2;2151:18;;2135:35;:::i;:::-;2125:45;;1935:241;;;;;:::o;2181:325::-;2249:6;2257;2310:2;2298:9;2289:7;2285:23;2281:32;2278:2;;;2331:6;2323;2316:22;2278:2;2375:9;2362:23;2394:31;2419:5;2394:31;:::i;:::-;2444:5;2496:2;2481:18;;;;2468:32;;-1:-1:-1;;;2268:238:1:o;2511:190::-;2567:6;2620:2;2608:9;2599:7;2595:23;2591:32;2588:2;;;2641:6;2633;2626:22;2588:2;2669:26;2685:9;2669:26;:::i;2706:258::-;2771:6;2779;2832:2;2820:9;2811:7;2807:23;2803:32;2800:2;;;2853:6;2845;2838:22;2800:2;2881:26;2897:9;2881:26;:::i;2969:395::-;3052:6;3060;3068;3076;3129:3;3117:9;3108:7;3104:23;3100:33;3097:2;;;3151:6;3143;3136:22;3097:2;3179:26;3195:9;3179:26;:::i;:::-;3169:36;3252:2;3237:18;;3224:32;;-1:-1:-1;3303:2:1;3288:18;;3275:32;;3354:2;3339:18;3326:32;;-1:-1:-1;3087:277:1;-1:-1:-1;;;3087:277:1:o;3369:190::-;3428:6;3481:2;3469:9;3460:7;3456:23;3452:32;3449:2;;;3502:6;3494;3487:22;3449:2;-1:-1:-1;3530:23:1;;3439:120;-1:-1:-1;3439:120:1:o;3564:258::-;3629:6;3637;3690:2;3678:9;3669:7;3665:23;3661:32;3658:2;;;3711:6;3703;3696:22;3658:2;3752:9;3739:23;3729:33;;3781:35;3812:2;3801:9;3797:18;3781:35;:::i;3827:258::-;3895:6;3903;3956:2;3944:9;3935:7;3931:23;3927:32;3924:2;;;3977:6;3969;3962:22;3924:2;-1:-1:-1;;4005:23:1;;;4075:2;4060:18;;;4047:32;;-1:-1:-1;3914:171:1:o;4090:326::-;4167:6;4175;4183;4236:2;4224:9;4215:7;4211:23;4207:32;4204:2;;;4257:6;4249;4242:22;4204:2;-1:-1:-1;;4285:23:1;;;4355:2;4340:18;;4327:32;;-1:-1:-1;4406:2:1;4391:18;;;4378:32;;4194:222;-1:-1:-1;4194:222:1:o;4421:316::-;4509:6;4517;4525;4578:2;4566:9;4557:7;4553:23;4549:32;4546:2;;;4599:6;4591;4584:22;4546:2;4633:9;4627:16;4617:26;;4683:2;4672:9;4668:18;4662:25;4652:35;;4727:2;4716:9;4712:18;4706:25;4696:35;;4536:201;;;;;:::o;4742:464::-;4837:6;4845;4853;4861;4869;4922:3;4910:9;4901:7;4897:23;4893:33;4890:2;;;4944:6;4936;4929:22;4890:2;-1:-1:-1;;4972:23:1;;;5042:2;5027:18;;5014:32;;-1:-1:-1;5093:2:1;5078:18;;5065:32;;5144:2;5129:18;;5116:32;;-1:-1:-1;5195:3:1;5180:19;5167:33;;-1:-1:-1;4880:326:1;-1:-1:-1;4880:326:1:o;5211:463::-;5264:3;5302:5;5296:12;5329:6;5324:3;5317:19;5355:4;5384:2;5379:3;5375:12;5368:19;;5421:2;5414:5;5410:14;5442:3;5454:195;5468:6;5465:1;5462:13;5454:195;;;5533:13;;-1:-1:-1;;;;;5529:39:1;5517:52;;5589:12;;;;5624:15;;;;5565:1;5483:9;5454:195;;;-1:-1:-1;5665:3:1;;5272:402;-1:-1:-1;;;;;5272:402:1:o;7943:510::-;8214:6;8203:9;8196:25;8257:3;8252:2;8241:9;8237:18;8230:31;8177:4;8278:57;8330:3;8319:9;8315:19;8307:6;8278:57;:::i;:::-;-1:-1:-1;;;;;8371:32:1;;;;8366:2;8351:18;;8344:60;-1:-1:-1;8435:2:1;8420:18;8413:34;8270:65;8186:267;-1:-1:-1;;8186:267:1:o;8458:603::-;8570:4;8599:2;8628;8617:9;8610:21;8660:6;8654:13;8703:6;8698:2;8687:9;8683:18;8676:34;8728:4;8741:140;8755:6;8752:1;8749:13;8741:140;;;8850:14;;;8846:23;;8840:30;8816:17;;;8835:2;8812:26;8805:66;8770:10;;8741:140;;;8899:6;8896:1;8893:13;8890:2;;;8969:4;8964:2;8955:6;8944:9;8940:22;8936:31;8929:45;8890:2;-1:-1:-1;9045:2:1;9024:15;-1:-1:-1;;9020:29:1;9005:45;;;;9052:2;9001:54;;8579:482;-1:-1:-1;;;8579:482:1:o;9424:329::-;9626:2;9608:21;;;9665:1;9645:18;;;9638:29;-1:-1:-1;;;9698:2:1;9683:18;;9676:36;9744:2;9729:18;;9598:155::o;9758:335::-;9960:2;9942:21;;;9999:2;9979:18;;;9972:30;-1:-1:-1;;;10033:2:1;10018:18;;10011:41;10084:2;10069:18;;9932:161::o;10708:582::-;11007:6;10996:9;10989:25;11050:6;11045:2;11034:9;11030:18;11023:34;11093:3;11088:2;11077:9;11073:18;11066:31;10970:4;11114:57;11166:3;11155:9;11151:19;11143:6;11114:57;:::i;:::-;-1:-1:-1;;;;;11207:32:1;;;;11202:2;11187:18;;11180:60;-1:-1:-1;11271:3:1;11256:19;11249:35;11106:65;10979:311;-1:-1:-1;;;10979:311:1:o;11737:128::-;11777:3;11808:1;11804:6;11801:1;11798:13;11795:2;;;11814:18;;:::i;:::-;-1:-1:-1;11850:9:1;;11785:80::o;11870:217::-;11910:1;11936;11926:2;;-1:-1:-1;;;11961:31:1;;12015:4;12012:1;12005:15;12043:4;11968:1;12033:15;11926:2;-1:-1:-1;12072:9:1;;11916:171::o;12092:168::-;12132:7;12198:1;12194;12190:6;12186:14;12183:1;12180:21;12175:1;12168:9;12161:17;12157:45;12154:2;;;12205:18;;:::i;:::-;-1:-1:-1;12245:9:1;;12144:116::o;12265:125::-;12305:4;12333:1;12330;12327:8;12324:2;;;12338:18;;:::i;:::-;-1:-1:-1;12375:9:1;;12314:76::o;12395:380::-;12474:1;12470:12;;;;12517;;;12538:2;;12592:4;12584:6;12580:17;12570:27;;12538:2;12645;12637:6;12634:14;12614:18;12611:38;12608:2;;;12691:10;12686:3;12682:20;12679:1;12672:31;12726:4;12723:1;12716:15;12754:4;12751:1;12744:15;12608:2;;12450:325;;;:::o;12780:127::-;12841:10;12836:3;12832:20;12829:1;12822:31;12872:4;12869:1;12862:15;12896:4;12893:1;12886:15;12912:131;-1:-1:-1;;;;;12987:31:1;;12977:42;;12967:2;;13033:1;13030;13023:12;12967:2;12957:86;:::o

Swarm Source

ipfs://ed920347aec7c9fad5e52a9669a33e6c7bbb8ebc5f39973bbfe2ac8bf61ed277

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.