ETH Price: $2,407.47 (-0.44%)

Contract

0x3176180974144D376f005Cbde2e6c3F6FE0e8529
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Approve204542132024-08-04 9:12:1142 days ago1722762731IN
0x31761809...6FE0e8529
0 ETH0.000074791.5968634
Approve204377162024-08-02 1:56:3544 days ago1722563795IN
0x31761809...6FE0e8529
0 ETH0.000142773.0256475
Approve204312472024-08-01 4:15:4745 days ago1722485747IN
0x31761809...6FE0e8529
0 ETH0.000222384.71281314
Transfer204120232024-07-29 11:48:4748 days ago1722253727IN
0x31761809...6FE0e8529
0 ETH0.00024773.81831265
Approve203730392024-07-24 1:12:5953 days ago1721783579IN
0x31761809...6FE0e8529
0 ETH0.000085731.82658357
Approve203512352024-07-21 0:09:5956 days ago1721520599IN
0x31761809...6FE0e8529
0 ETH0.000141462.99784155
Transfer203453672024-07-20 4:31:1157 days ago1721449871IN
0x31761809...6FE0e8529
0 ETH0.000190462.93375192
Approve203443792024-07-20 1:11:4757 days ago1721437907IN
0x31761809...6FE0e8529
0 ETH0.000144923.075198
Approve203384922024-07-19 5:29:3558 days ago1721366975IN
0x31761809...6FE0e8529
0 ETH0.000368527.81961532
Approve203371182024-07-19 0:53:5958 days ago1721350439IN
0x31761809...6FE0e8529
0 ETH0.0004880410.40869806
Approve203369372024-07-19 0:17:3558 days ago1721348255IN
0x31761809...6FE0e8529
0 ETH0.00036077.64406716
Approve203368022024-07-18 23:50:2358 days ago1721346623IN
0x31761809...6FE0e8529
0 ETH0.000302686.41435367
Approve203366062024-07-18 23:11:1158 days ago1721344271IN
0x31761809...6FE0e8529
0 ETH0.000355097.52503268
Approve203357092024-07-18 20:10:5958 days ago1721333459IN
0x31761809...6FE0e8529
0 ETH0.0005703712.10264445
Approve203355292024-07-18 19:34:5958 days ago1721331299IN
0x31761809...6FE0e8529
0 ETH0.0005480811.61485192
Approve203355162024-07-18 19:32:2358 days ago1721331143IN
0x31761809...6FE0e8529
0 ETH0.0006066612.85637889
Approve203346562024-07-18 16:39:2358 days ago1721320763IN
0x31761809...6FE0e8529
0 ETH0.0006304613.36079622
Approve203345752024-07-18 16:23:1158 days ago1721319791IN
0x31761809...6FE0e8529
0 ETH0.000556111.78781585
Approve203345362024-07-18 16:15:2358 days ago1721319323IN
0x31761809...6FE0e8529
0 ETH0.0010487322.36687761
Approve203345272024-07-18 16:13:3558 days ago1721319215IN
0x31761809...6FE0e8529
0 ETH0.001000121.1939726
Approve203345102024-07-18 16:10:1158 days ago1721319011IN
0x31761809...6FE0e8529
0 ETH0.0011626724.67057339
Approve203344712024-07-18 16:02:2358 days ago1721318543IN
0x31761809...6FE0e8529
0 ETH0.0011323123.99579875
Approve203344682024-07-18 16:01:4758 days ago1721318507IN
0x31761809...6FE0e8529
0 ETH0.0010940123.33257921
Approve203344392024-07-18 15:55:5958 days ago1721318159IN
0x31761809...6FE0e8529
0 ETH0.0008432417.86996631
Approve203343902024-07-18 15:46:1158 days ago1721317571IN
0x31761809...6FE0e8529
0 ETH0.0007647116.20574463
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Block From To
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.15278111 ETH
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.15278111 ETH
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.02087051 ETH
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.02087051 ETH
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.26865728 ETH
203342752024-07-18 15:22:5958 days ago1721316179
0x31761809...6FE0e8529
0.26865728 ETH
203342742024-07-18 15:22:4758 days ago1721316167
0x31761809...6FE0e8529
0.34324147 ETH
203342742024-07-18 15:22:4758 days ago1721316167
0x31761809...6FE0e8529
0.34324147 ETH
203342572024-07-18 15:19:2358 days ago1721315963
0x31761809...6FE0e8529
0.13441869 ETH
203342572024-07-18 15:19:2358 days ago1721315963
0x31761809...6FE0e8529
0.13441869 ETH
203342562024-07-18 15:19:1158 days ago1721315951
0x31761809...6FE0e8529
0.09777927 ETH
203342562024-07-18 15:19:1158 days ago1721315951
0x31761809...6FE0e8529
0.09777927 ETH
203342142024-07-18 15:10:4758 days ago1721315447
0x31761809...6FE0e8529
0.04951022 ETH
203342142024-07-18 15:10:4758 days ago1721315447
0x31761809...6FE0e8529
0.04951022 ETH
203342082024-07-18 15:09:3558 days ago1721315375
0x31761809...6FE0e8529
0.25988444 ETH
203342082024-07-18 15:09:3558 days ago1721315375
0x31761809...6FE0e8529
0.25988444 ETH
203342062024-07-18 15:09:1158 days ago1721315351
0x31761809...6FE0e8529
0.20179923 ETH
203342062024-07-18 15:09:1158 days ago1721315351
0x31761809...6FE0e8529
0.20179923 ETH
203341972024-07-18 15:07:2358 days ago1721315243
0x31761809...6FE0e8529
0.00920916 ETH
203341972024-07-18 15:07:2358 days ago1721315243
0x31761809...6FE0e8529
0.00920916 ETH
203341972024-07-18 15:07:2358 days ago1721315243
0x31761809...6FE0e8529
0.20321787 ETH
203341972024-07-18 15:07:2358 days ago1721315243
0x31761809...6FE0e8529
0.20321787 ETH
203341902024-07-18 15:05:5958 days ago1721315159
0x31761809...6FE0e8529
0.35115013 ETH
203341902024-07-18 15:05:5958 days ago1721315159
0x31761809...6FE0e8529
0.35115013 ETH
203341892024-07-18 15:05:4758 days ago1721315147
0x31761809...6FE0e8529
0.19911641 ETH
View All Internal Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
Pigeon

Compiler Version
v0.8.26+commit.8a97fa7a

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 10 : Pigeon.sol
// SPDX-License-Identifier: MIT
/*

$PIGEON is meme token for charity with the conveyed message “MAKE PEACE NOT WAR” 

https://t.me/pigeoncoincommunity

https://pigeoncoin.vip/

https://x.com/pigeoncoinvip

*/
pragma solidity ^0.8.24;

import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import {Context} from "@openzeppelin/contracts/utils/Context.sol";
import "@openzeppelin/contracts/utils/math/SafeMath.sol";
import {IUniswapV2Router02} from "./interface/IUniswapV2Router02.sol";
import {IUniswapV2Factory} from "./interface/IUniswapV2Factory.sol";
import {IPigeonCharity} from "./interface/IPigeonCharity.sol";
import "./PigeonCharity.sol";

contract Pigeon is Context, Ownable, IERC20 {
    using SafeMath for uint256;
    address constant DEAD = 0x000000000000000000000000000000000000dEaD;

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExcludedFromFee;
    address payable private _taxWallet;

    uint256 private _initialBuyTax = 20; // 20%
    uint256 private _initialSellTax = 20;

    uint256 private _finalBuyTax = 1; // 1%
    uint256 private _finalSellTax = 0;

    uint256 private _reduceBuyTaxAt = 30;
    uint256 private _reduceSellTaxAt = 31;

    uint256 private _preventSwapBefore = 32;

    uint256 private _transferTax = 0;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 18;
    uint256 private constant _tTotal = 420_690_000_000 * 10 ** _decimals;

    string private constant _name = unicode"Pigeon Coin";
    string private constant _symbol = unicode"PIGEON";

    uint256 public _maxTxAmount = (_tTotal * 3) / 100;
    uint256 public _maxWalletSize = (_tTotal * 3) / 100;
    uint256 public _taxSwapThreshold = (_tTotal * 1) / 1000;
    uint256 public _maxTaxSwap = (_tTotal * 1) / 100;

    IUniswapV2Router02 public uniswapV2Router;
    address private uniswapV2Pair;
    address private pigeonCharity;

    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;

    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;
    uint256 private firstBlock = 0;

    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);
    event ClearToken(address TokenAddressCleared, uint256 Amount);
    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() {
        _taxWallet = payable(0xbA6cd6Fc91EB77B38069f363AA41132411E5151e);
        _balances[_msgSender()] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        address _v2Router;

        // @dev assumes WETH pair
        if (block.chainid == 1) {
            _v2Router = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
        } else if (block.chainid == 5) {
            _v2Router = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
        } else if (block.chainid == 97) {
            _v2Router = 0xD99D1c33F9fC3444f8101754aBC46c52416550D1;
        } else if (block.chainid == 42161) {
            _v2Router = 0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506;
        } else if (block.chainid == 8453) {
            _v2Router = 0x4752ba5DBc23f44D87826276BF6Fd6b1C372aD24;
        } else if (block.chainid == 1337) {
            _v2Router = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
        } else {
            revert("Chain not configured");
        }

        uniswapV2Router = IUniswapV2Router02(_v2Router);
        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

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

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

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

    function transfer(
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

    function approve(
        address spender,
        uint256 amount
    ) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount = 0;
        if (from != owner() && to != owner()) {
            if (_buyCount == 0) {
                taxAmount = amount
                    .mul(
                        (_buyCount > _reduceBuyTaxAt)
                            ? _finalBuyTax
                            : _initialBuyTax
                    )
                    .div(100);
            }

            if (_buyCount > 0) {
                taxAmount = amount.mul(_transferTax).div(100);
            }

            if (block.number == firstBlock) {
                require(_buyCount < 24, "Exceeds buys on the first block.");
            }

            if (
                from == uniswapV2Pair &&
                to != address(uniswapV2Router) &&
                !_isExcludedFromFee[to]
            ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
                taxAmount = amount
                    .mul(
                        (_buyCount > _reduceBuyTaxAt)
                            ? _finalBuyTax
                            : _initialBuyTax
                    )
                    .div(100);
                _buyCount++;
            }

            if (to == uniswapV2Pair && from != address(this)) {
                taxAmount = amount
                    .mul(
                        (_buyCount > _reduceSellTaxAt)
                            ? _finalSellTax
                            : _initialSellTax
                    )
                    .div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap &&
                to == uniswapV2Pair &&
                swapEnabled &&
                contractTokenBalance > _taxSwapThreshold &&
                _buyCount > _preventSwapBefore
            ) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 3, "Only 3 sells per block!");

                swapTokensForEth(
                    min(amount, min(contractTokenBalance, _maxTaxSwap))
                );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }

                sellCount++;
                lastSellBlock = block.number;
            }
        }

        if (taxAmount > 0) {
            // @dev 1% tax for charity
            uint256 charityTax = amount.mul(1).div(100);
            if (charityTax > 0 && taxAmount >= charityTax) {
                donate(from, charityTax);
            }

            if (taxAmount > charityTax) {
                uint256 platformTax = taxAmount - charityTax;

                _balances[address(this)] = _balances[address(this)].add(
                    platformTax
                );
                emit Transfer(from, address(this), platformTax);
            }
        }

        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));

        emit Transfer(from, to, amount.sub(taxAmount));
    }

    function min(uint256 a, uint256 b) private pure returns (uint256) {
        return (a > b) ? b : a;
    }

    function donate(address _from, uint256 _amount) private {
        if(address(pigeonCharity) == address(0)) {
            return;
        }
        _balances[address(pigeonCharity)] = _balances[address(pigeonCharity)]
            .add(_amount);
        
        emit Transfer(_from, address(pigeonCharity), _amount);
        IPigeonCharity(pigeonCharity).tokenDonateFor(_amount, _from);
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function removeLimit() external onlyOwner {
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }
    function setChairty(address _charityAddr) external onlyOwner {
        pigeonCharity = _charityAddr;
    }

    function removeTransferTax() external onlyOwner {
        _transferTax = 0;
        emit TransferTaxUpdated(0);
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function openTrading() external onlyOwner {
        require(!tradingOpen, "trading is already open");
        _approve(address(this), address(uniswapV2Router), _tTotal);

        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            uniswapV2Router.WETH()
        );
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            DEAD, // @dev burn LP
            block.timestamp
        );
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
        firstBlock = block.number;
    }

    receive() external payable {}

    function reduceFee(uint256 _newFee) external {
        require(_msgSender() == _taxWallet);
        require(_newFee <= _finalBuyTax && _newFee <= _finalSellTax);

        _finalBuyTax = _newFee;
        _finalSellTax = _newFee;
    }

    function clearStuckToken(
        address tokenAddress,
        uint256 tokens
    ) external returns (bool success) {
        require(_msgSender() == _taxWallet);

        if (tokens == 0) {
            tokens = IERC20(tokenAddress).balanceOf(address(this));
            _taxWallet.transfer(address(this).balance);
        }

        emit ClearToken(tokenAddress, tokens);
        return IERC20(tokenAddress).transfer(_taxWallet, tokens);
    }

    function manualSend() external {
        require(_msgSender() == _taxWallet);

        uint256 ethBalance = address(this).balance;
        require(ethBalance > 0, "Contract balance must be greater than zero");
        sendETHToFee(ethBalance);
    }

    function manualSwap() external {
        require(_msgSender() == _taxWallet);

        uint256 tokenBalance = balanceOf(address(this));
        if (tokenBalance > 0) {
            swapTokensForEth(tokenBalance);
        }

        uint256 ethBalance = address(this).balance;
        if (ethBalance > 0) {
            sendETHToFee(ethBalance);
        }
    }
}

File 2 of 10 : PigeonCharity.sol
// SPDX-License-Identifier: MIT
/*

$PIGEON is meme token for charity with the conveyed message “MAKE PEACE NOT WAR” 

https://t.me/pigeoncoincommunity

https://pigeoncoin.vip/

https://x.com/pigeoncoinvip

*/
pragma solidity ^0.8.24;

import "@openzeppelin/contracts/utils/math/SafeMath.sol";
import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import "@openzeppelin/contracts/security/ReentrancyGuard.sol";

contract PigeonCharity is Ownable, ReentrancyGuard {
    IERC20 public token;

    using SafeMath for uint256;

    uint256 public totalCharity;
    uint256 public lastTimeWithdrawn;
    uint256 public totalWithdrawn;

    uint256 constant lockTime = 365 days;
    uint256 constant baseDivider = 10000;
    uint256 constant vestingPercent = 500;

    mapping(address => Supporter) public supporter;

    address private executioner;

    struct Supporter {
        string content;
        uint256 cumulative_amount;
    }

    event Donate(address indexed sender, uint256 amount, uint256 time);
    event Withdraw(uint256 amount, uint256 time);

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyExecutioner() {
        _checkExecutioner();
        _;
    }

    constructor() {}
    // Function to receive Ether. msg.data must be empty
    receive() external payable {}
    /**
     * @notice Allows the user donate token
     * @dev Callable by everyone
     */
    function donate(uint256 _amount) external nonReentrant {
        // Transfer Token
        token.transferFrom(msg.sender, address(this), _amount);

        supporter[msg.sender].cumulative_amount += _amount;

        totalCharity += _amount;

        emit Donate(msg.sender, _amount, block.timestamp);
    }
    function donateFor(uint256 _amount, address _for, string calldata _info) external nonReentrant {
        // Transfer Token
        token.transferFrom(msg.sender, address(this), _amount);

        if(supporter[_for].cumulative_amount == 0){
            supporter[_for].content = _info;
        }
        
        supporter[_for].cumulative_amount += _amount;
        totalCharity += _amount;

        emit Donate(_for, _amount, block.timestamp);
    }

    function tokenDonateFor(uint256 _amount, address _for) external nonReentrant {
        require(address(token) == msg.sender, "PigeonCharity: Only Token");
        
        supporter[_for].cumulative_amount += _amount;
        totalCharity += _amount;

        emit Donate(_for, _amount, block.timestamp);
    }

    /**
     * @notice Allows the user set info
     * @dev Callable by everyone
     */
    function setInfo(string calldata _info) external {
        supporter[msg.sender].content = _info;
    }

    /**
     * @notice Allows the owner set token
     * @dev Callable by owner
     */
    function setToken(address _token) external onlyOwner {
        token = IERC20(_token);
        lastTimeWithdrawn = block.timestamp;
    }
    /**
     * @notice Allows the owner set executioner
     * @dev Callable by owner
     */
    function setExecutioner(address _executioner) external nonReentrant {
        require(
            address(msg.sender) == executioner ||
                address(msg.sender) == owner(),
            "PigeonCharity: Not ROLE!"
        );
        executioner = _executioner;
    }
    /**
     * @notice Allows the executioner withdraw token at the unlock time
     * @dev Callable by executioner
     */
    function withdraw() external onlyExecutioner nonReentrant {
        require(
            lastTimeWithdrawn + lockTime <= block.timestamp,
            "PigeonCharity: It's not time to unlock yet!"
        );
        uint256 remain = IERC20(token).balanceOf(address(this));
        uint256 amount = (remain * vestingPercent) / baseDivider;

        IERC20(token).transfer(address(msg.sender), amount);

        lastTimeWithdrawn = block.timestamp;
        totalWithdrawn += amount;

        emit Withdraw(amount, block.timestamp);
    }

    /**
     * @dev Throws if the sender is not the executioner.
     */
    function _checkExecutioner() internal view virtual {
        require(
            executioner == _msgSender(),
            "PigeonCharity: caller is not the executioner"
        );
    }
}

File 3 of 10 : IPigeonCharity.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.24;

interface IPigeonCharity {
    function donateFor(
        uint256 _amount,
        address _for,
        string calldata _info
    ) external;
    function tokenDonateFor(uint256 _amount, address _for) external;
}

File 4 of 10 : IUniswapV2Factory.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.24;

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

    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(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

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

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

File 5 of 10 : IUniswapV2Router02.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.24;

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

File 6 of 10 : SafeMath.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (utils/math/SafeMath.sol)

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 generally not needed starting with Solidity 0.8, since 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 subtraction 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;
        }
    }
}

File 7 of 10 : Context.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.4) (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }

    function _contextSuffixLength() internal view virtual returns (uint256) {
        return 0;
    }
}

File 8 of 10 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `from` to `to` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address from, address to, uint256 amount) external returns (bool);
}

File 9 of 10 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby disabling any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

File 10 of 10 : ReentrancyGuard.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (security/ReentrancyGuard.sol)

pragma solidity ^0.8.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and making it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        _nonReentrantBefore();
        _;
        _nonReentrantAfter();
    }

    function _nonReentrantBefore() private {
        // On the first call to nonReentrant, _status will be _NOT_ENTERED
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;
    }

    function _nonReentrantAfter() private {
        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a
     * `nonReentrant` function in the call stack.
     */
    function _reentrancyGuardEntered() internal view returns (bool) {
        return _status == _ENTERED;
    }
}

Settings
{
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","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":"address","name":"TokenAddressCleared","type":"address"},{"indexed":false,"internalType":"uint256","name":"Amount","type":"uint256"}],"name":"ClearToken","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"_maxTxAmount","type":"uint256"}],"name":"MaxTxAmountUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"_tax","type":"uint256"}],"name":"TransferTaxUpdated","type":"event"},{"inputs":[],"name":"_maxTaxSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxWalletSize","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxSwapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","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":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"clearStuckToken","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"manualSend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"manualSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"openTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newFee","type":"uint256"}],"name":"reduceFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"removeLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"removeTransferTax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_charityAddr","type":"address"}],"name":"setChairty","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","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","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60806040526014600555601460065560016007555f600855601e600955601f600a556020600b555f600c555f600d55606460036012600a61004091906107b9565b6461f313f8806100509190610803565b61005a9190610803565b6100649190610871565b600e55606460036012600a61007991906107b9565b6461f313f8806100899190610803565b6100939190610803565b61009d9190610871565b600f556103e860016012600a6100b391906107b9565b6461f313f8806100c39190610803565b6100cd9190610803565b6100d79190610871565b601055606460016012600a6100ec91906107b9565b6461f313f8806100fc9190610803565b6101069190610803565b6101109190610871565b6011555f601460156101000a81548160ff0219169083151502179055505f601460166101000a81548160ff0219169083151502179055505f6015555f6016555f60175534801561015e575f80fd5b5061017b61017061055960201b60201c565b61056060201b60201c565b73ba6cd6fc91eb77b38069f363aa41132411e5151e60045f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506012600a6101dd91906107b9565b6461f313f8806101ed9190610803565b60015f6101fe61055960201b60201c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550600160035f61024e61062160201b60201c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550600160035f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550600160035f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055505f6001460361038d57737a250d5630b4cf539739df2c5dacb4c659f2488d9050610484565b600546036103b157737a250d5630b4cf539739df2c5dacb4c659f2488d9050610483565b606146036103d55773d99d1c33f9fc3444f8101754abc46c52416550d19050610482565b61a4b146036103fa57731b02da8cb0d097eb8d57a175b88c7d8b479975069050610481565b612105460361041f57734752ba5dbc23f44d87826276bf6fd6b1c372ad249050610480565b610539460361044457737a250d5630b4cf539739df2c5dacb4c659f2488d905061047f565b6040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610476906108fb565b60405180910390fd5b5b5b5b5b5b8060125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506104d261055960201b60201c565b73ffffffffffffffffffffffffffffffffffffffff165f73ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6012600a61052e91906107b9565b6461f313f88061053e9190610803565b60405161054b9190610928565b60405180910390a350610941565b5f33905090565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156106ca578086048111156106a6576106a5610648565b5b60018516156106b55780820291505b80810290506106c385610675565b945061068a565b94509492505050565b5f826106e2576001905061079d565b816106ef575f905061079d565b8160018114610705576002811461070f5761073e565b600191505061079d565b60ff84111561072157610720610648565b5b8360020a91508482111561073857610737610648565b5b5061079d565b5060208310610133831016604e8410600b84101617156107735782820a90508381111561076e5761076d610648565b5b61079d565b6107808484846001610681565b9250905081840481111561079757610796610648565b5b81810290505b9392505050565b5f819050919050565b5f60ff82169050919050565b5f6107c3826107a4565b91506107ce836107ad565b92506107fb7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846106d3565b905092915050565b5f61080d826107a4565b9150610818836107a4565b9250828202610826816107a4565b9150828204841483151761083d5761083c610648565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61087b826107a4565b9150610886836107a4565b92508261089657610895610844565b5b828204905092915050565b5f82825260208201905092915050565b7f436861696e206e6f7420636f6e666967757265640000000000000000000000005f82015250565b5f6108e56014836108a1565b91506108f0826108b1565b602082019050919050565b5f6020820190508181035f830152610912816108d9565b9050919050565b610922816107a4565b82525050565b5f60208201905061093b5f830184610919565b92915050565b6135d78061094e5f395ff3fe608060405260043610610169575f3560e01c8063715018a6116100d0578063a9059cbb11610089578063dd62ed3e11610063578063dd62ed3e146104da578063ec1f3f6314610516578063f2fde38b1461053e578063f42938901461056657610170565b8063a9059cbb1461045e578063bf474bed1461049a578063c9567bf9146104c457610170565b8063715018a61461036457806377b54bad1461037a5780637d1db4a5146103b65780638da5cb5b146103e05780638f9a55c01461040a57806395d89b411461043457610170565b806323b872dd1161012257806323b872dd1461026e578063313ce567146102aa57806331acbe06146102d457806351bc3c85146102fc578063622565891461031257806370a082311461032857610170565b806306fdde0314610174578063095ea7b31461019e5780630faee56f146101da578063109daa99146102045780631694505e1461021a57806318160ddd1461024457610170565b3661017057005b5f80fd5b34801561017f575f80fd5b5061018861057c565b604051610195919061253f565b60405180910390f35b3480156101a9575f80fd5b506101c460048036038101906101bf91906125f0565b6105b9565b6040516101d19190612648565b60405180910390f35b3480156101e5575f80fd5b506101ee6105d6565b6040516101fb9190612670565b60405180910390f35b34801561020f575f80fd5b506102186105dc565b005b348015610225575f80fd5b5061022e610624565b60405161023b91906126e4565b60405180910390f35b34801561024f575f80fd5b50610258610649565b6040516102659190612670565b60405180910390f35b348015610279575f80fd5b50610294600480360381019061028f91906126fd565b61066d565b6040516102a19190612648565b60405180910390f35b3480156102b5575f80fd5b506102be610741565b6040516102cb9190612768565b60405180910390f35b3480156102df575f80fd5b506102fa60048036038101906102f59190612781565b610749565b005b348015610307575f80fd5b50610310610794565b005b34801561031d575f80fd5b5061032661082b565b005b348015610333575f80fd5b5061034e60048036038101906103499190612781565b6108d1565b60405161035b9190612670565b60405180910390f35b34801561036f575f80fd5b50610378610917565b005b348015610385575f80fd5b506103a0600480360381019061039b91906125f0565b61092a565b6040516103ad9190612648565b60405180910390f35b3480156103c1575f80fd5b506103ca610b4e565b6040516103d79190612670565b60405180910390f35b3480156103eb575f80fd5b506103f4610b54565b60405161040191906127bb565b60405180910390f35b348015610415575f80fd5b5061041e610b7b565b60405161042b9190612670565b60405180910390f35b34801561043f575f80fd5b50610448610b81565b604051610455919061253f565b60405180910390f35b348015610469575f80fd5b50610484600480360381019061047f91906125f0565b610bbe565b6040516104919190612648565b60405180910390f35b3480156104a5575f80fd5b506104ae610bdb565b6040516104bb9190612670565b60405180910390f35b3480156104cf575f80fd5b506104d8610be1565b005b3480156104e5575f80fd5b5061050060048036038101906104fb91906127d4565b611023565b60405161050d9190612670565b60405180910390f35b348015610521575f80fd5b5061053c60048036038101906105379190612812565b6110a5565b005b348015610549575f80fd5b50610564600480360381019061055f9190612781565b611131565b005b348015610571575f80fd5b5061057a6111b3565b005b60606040518060400160405280600b81526020017f506967656f6e20436f696e000000000000000000000000000000000000000000815250905090565b5f6105cc6105c5611264565b848461126b565b6001905092915050565b60115481565b6105e461142e565b5f600c819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f60405161061a9190612876565b60405180910390a1565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f6012600a61065891906129eb565b6461f313f8806106689190612a35565b905090565b5f6106798484846114ac565b61073684610685611264565b6107318560405180606001604052806028815260200161357a6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6106e8611264565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611e3f9092919063ffffffff16565b61126b565b600190509392505050565b5f6012905090565b61075161142e565b8060145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166107d4611264565b73ffffffffffffffffffffffffffffffffffffffff16146107f3575f80fd5b5f6107fd306108d1565b90505f8111156108115761081081611e93565b5b5f4790505f81111561082757610826816120fe565b5b5050565b61083361142e565b6012600a61084191906129eb565b6461f313f8806108519190612a35565b600e819055506012600a61086591906129eb565b6461f313f8806108759190612a35565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a6108aa91906129eb565b6461f313f8806108ba9190612a35565b6040516108c79190612670565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61091f61142e565b6109285f612166565b565b5f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661096b611264565b73ffffffffffffffffffffffffffffffffffffffff161461098a575f80fd5b5f8203610a71578273ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b81526004016109ca91906127bb565b602060405180830381865afa1580156109e5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a099190612a8a565b915060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f19350505050158015610a6f573d5f803e3d5ffd5b505b7fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f8383604051610aa2929190612ab5565b60405180910390a18273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846040518363ffffffff1660e01b8152600401610b06929190612afc565b6020604051808303815f875af1158015610b22573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b469190612b4d565b905092915050565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600681526020017f504947454f4e0000000000000000000000000000000000000000000000000000815250905090565b5f610bd1610bca611264565b84846114ac565b6001905092915050565b60105481565b610be961142e565b60148054906101000a900460ff1615610c37576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c2e90612bc2565b60405180910390fd5b610c803060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166012600a610c6b91906129eb565b6461f313f880610c7b9190612a35565b61126b565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cea573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d0e9190612bf4565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d94573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610db89190612bf4565b6040518363ffffffff1660e01b8152600401610dd5929190612c1f565b6020604051808303815f875af1158015610df1573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e159190612bf4565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610e9c306108d1565b5f8061dead426040518863ffffffff1660e01b8152600401610ec396959493929190612c46565b60606040518083038185885af1158015610edf573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610f049190612ca5565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610fa4929190612ab5565b6020604051808303815f875af1158015610fc0573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fe49190612b4d565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff02191690831515021790555043601781905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166110e5611264565b73ffffffffffffffffffffffffffffffffffffffff1614611104575f80fd5b600754811115801561111857506008548111155b611120575f80fd5b806007819055508060088190555050565b61113961142e565b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036111a7576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161119e90612d65565b60405180910390fd5b6111b081612166565b50565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166111f3611264565b73ffffffffffffffffffffffffffffffffffffffff1614611212575f80fd5b5f4790505f8111611258576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161124f90612df3565b60405180910390fd5b611261816120fe565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036112d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112d090612e81565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611347576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161133e90612f0f565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516114219190612670565b60405180910390a3505050565b611436611264565b73ffffffffffffffffffffffffffffffffffffffff16611454610b54565b73ffffffffffffffffffffffffffffffffffffffff16146114aa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a190612f77565b60405180910390fd5b565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361151a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161151190613005565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611588576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161157f90613093565b60405180910390fd5b5f81116115ca576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115c190613121565b60405180910390fd5b5f6115d3610b54565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156116415750611611610b54565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611b2c575f600d540361168e5761168b606461167d600954600d541161166a5760055461166e565b6007545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b5f600d5411156116c3576116c060646116b2600c548561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b6017544303611712576018600d5410611711576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161170890613189565b60405180910390fd5b5b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156117bb575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b801561180e575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561190657600e54821115611858576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161184f906131f1565b60405180910390fd5b600f5482611865856108d1565b61186f919061320f565b11156118b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118a79061328c565b60405180910390fd5b6118ec60646118de600954600d54116118cb576005546118cf565b6007545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b9050600d5f815480929190611900906132aa565b91905055505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561198e57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156119d2576119cf60646119c1600a54600d54116119ae576006546119b2565b6008545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b5f6119dc306108d1565b9050601460159054906101000a900460ff16158015611a47575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611a5f5750601460169054906101000a900460ff165b8015611a6c575060105481115b8015611a7b5750600b54600d54115b15611b2a57601654431115611a92575f6015819055505b600360155410611ad7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ace9061333b565b60405180910390fd5b611af4611aef84611aea84601154612251565b612251565b611e93565b5f4790505f811115611b0a57611b09476120fe565b5b60155f815480929190611b1c906132aa565b919050555043601681905550505b505b5f811115611c8e575f611b5c6064611b4e60018661222790919063ffffffff16565b61223c90919063ffffffff16565b90505f81118015611b6d5750808210155b15611b7d57611b7c8582612269565b5b80821115611c8c575f8183611b929190613359565b9050611be48160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611c829190612670565b60405180910390a3505b505b611cde8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124ba90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611d81611d3582846124ba90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611e2484866124ba90919063ffffffff16565b604051611e319190612670565b60405180910390a350505050565b5f838311158290611e86576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e7d919061253f565b60405180910390fd5b5082840390509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611eca57611ec961338c565b5b604051908082528060200260200182016040528015611ef85781602001602082028036833780820191505090505b50905030815f81518110611f0f57611f0e6133b9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611fb3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611fd79190612bf4565b81600181518110611feb57611fea6133b9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506120513060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff168461126b565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016120b395949392919061349d565b5f604051808303815f87803b1580156120ca575f80fd5b505af11580156120dc573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612162573d5f803e3d5ffd5b5050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f81836122349190612a35565b905092915050565b5f81836122499190613522565b905092915050565b5f81831161225f5782612261565b815b905092915050565b5f73ffffffffffffffffffffffffffffffffffffffff1660145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1603156124a15761232f8160015f60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161240f9190612670565b60405180910390a360145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663665263f482846040518363ffffffff1660e01b8152600401612473929190613552565b5f604051808303815f87803b15801561248a575f80fd5b505af115801561249c573d5f803e3d5ffd5b505050505b5050565b5f81836124b2919061320f565b905092915050565b5f81836124c79190613359565b905092915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f612511826124cf565b61251b81856124d9565b935061252b8185602086016124e9565b612534816124f7565b840191505092915050565b5f6020820190508181035f8301526125578184612507565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61258c82612563565b9050919050565b61259c81612582565b81146125a6575f80fd5b50565b5f813590506125b781612593565b92915050565b5f819050919050565b6125cf816125bd565b81146125d9575f80fd5b50565b5f813590506125ea816125c6565b92915050565b5f80604083850312156126065761260561255f565b5b5f612613858286016125a9565b9250506020612624858286016125dc565b9150509250929050565b5f8115159050919050565b6126428161262e565b82525050565b5f60208201905061265b5f830184612639565b92915050565b61266a816125bd565b82525050565b5f6020820190506126835f830184612661565b92915050565b5f819050919050565b5f6126ac6126a76126a284612563565b612689565b612563565b9050919050565b5f6126bd82612692565b9050919050565b5f6126ce826126b3565b9050919050565b6126de816126c4565b82525050565b5f6020820190506126f75f8301846126d5565b92915050565b5f805f606084860312156127145761271361255f565b5b5f612721868287016125a9565b9350506020612732868287016125a9565b9250506040612743868287016125dc565b9150509250925092565b5f60ff82169050919050565b6127628161274d565b82525050565b5f60208201905061277b5f830184612759565b92915050565b5f602082840312156127965761279561255f565b5b5f6127a3848285016125a9565b91505092915050565b6127b581612582565b82525050565b5f6020820190506127ce5f8301846127ac565b92915050565b5f80604083850312156127ea576127e961255f565b5b5f6127f7858286016125a9565b9250506020612808858286016125a9565b9150509250929050565b5f602082840312156128275761282661255f565b5b5f612834848285016125dc565b91505092915050565b5f819050919050565b5f61286061285b6128568461283d565b612689565b6125bd565b9050919050565b61287081612846565b82525050565b5f6020820190506128895f830184612867565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612911578086048111156128ed576128ec61288f565b5b60018516156128fc5780820291505b808102905061290a856128bc565b94506128d1565b94509492505050565b5f8261292957600190506129e4565b81612936575f90506129e4565b816001811461294c576002811461295657612985565b60019150506129e4565b60ff8411156129685761296761288f565b5b8360020a91508482111561297f5761297e61288f565b5b506129e4565b5060208310610133831016604e8410600b84101617156129ba5782820a9050838111156129b5576129b461288f565b5b6129e4565b6129c784848460016128c8565b925090508184048111156129de576129dd61288f565b5b81810290505b9392505050565b5f6129f5826125bd565b9150612a008361274d565b9250612a2d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff848461291a565b905092915050565b5f612a3f826125bd565b9150612a4a836125bd565b9250828202612a58816125bd565b91508282048414831517612a6f57612a6e61288f565b5b5092915050565b5f81519050612a84816125c6565b92915050565b5f60208284031215612a9f57612a9e61255f565b5b5f612aac84828501612a76565b91505092915050565b5f604082019050612ac85f8301856127ac565b612ad56020830184612661565b9392505050565b5f612ae6826126b3565b9050919050565b612af681612adc565b82525050565b5f604082019050612b0f5f830185612aed565b612b1c6020830184612661565b9392505050565b612b2c8161262e565b8114612b36575f80fd5b50565b5f81519050612b4781612b23565b92915050565b5f60208284031215612b6257612b6161255f565b5b5f612b6f84828501612b39565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612bac6017836124d9565b9150612bb782612b78565b602082019050919050565b5f6020820190508181035f830152612bd981612ba0565b9050919050565b5f81519050612bee81612593565b92915050565b5f60208284031215612c0957612c0861255f565b5b5f612c1684828501612be0565b91505092915050565b5f604082019050612c325f8301856127ac565b612c3f60208301846127ac565b9392505050565b5f60c082019050612c595f8301896127ac565b612c666020830188612661565b612c736040830187612867565b612c806060830186612867565b612c8d60808301856127ac565b612c9a60a0830184612661565b979650505050505050565b5f805f60608486031215612cbc57612cbb61255f565b5b5f612cc986828701612a76565b9350506020612cda86828701612a76565b9250506040612ceb86828701612a76565b9150509250925092565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f612d4f6026836124d9565b9150612d5a82612cf5565b604082019050919050565b5f6020820190508181035f830152612d7c81612d43565b9050919050565b7f436f6e74726163742062616c616e6365206d75737420626520677265617465725f8201527f207468616e207a65726f00000000000000000000000000000000000000000000602082015250565b5f612ddd602a836124d9565b9150612de882612d83565b604082019050919050565b5f6020820190508181035f830152612e0a81612dd1565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612e6b6024836124d9565b9150612e7682612e11565b604082019050919050565b5f6020820190508181035f830152612e9881612e5f565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612ef96022836124d9565b9150612f0482612e9f565b604082019050919050565b5f6020820190508181035f830152612f2681612eed565b9050919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612f616020836124d9565b9150612f6c82612f2d565b602082019050919050565b5f6020820190508181035f830152612f8e81612f55565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612fef6025836124d9565b9150612ffa82612f95565b604082019050919050565b5f6020820190508181035f83015261301c81612fe3565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f61307d6023836124d9565b915061308882613023565b604082019050919050565b5f6020820190508181035f8301526130aa81613071565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61310b6029836124d9565b9150613116826130b1565b604082019050919050565b5f6020820190508181035f830152613138816130ff565b9050919050565b7f457863656564732062757973206f6e2074686520666972737420626c6f636b2e5f82015250565b5f6131736020836124d9565b915061317e8261313f565b602082019050919050565b5f6020820190508181035f8301526131a081613167565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6131db6019836124d9565b91506131e6826131a7565b602082019050919050565b5f6020820190508181035f830152613208816131cf565b9050919050565b5f613219826125bd565b9150613224836125bd565b925082820190508082111561323c5761323b61288f565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f613276601a836124d9565b915061328182613242565b602082019050919050565b5f6020820190508181035f8301526132a38161326a565b9050919050565b5f6132b4826125bd565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036132e6576132e561288f565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f6133256017836124d9565b9150613330826132f1565b602082019050919050565b5f6020820190508181035f83015261335281613319565b9050919050565b5f613363826125bd565b915061336e836125bd565b92508282039050818111156133865761338561288f565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61341881612582565b82525050565b5f613429838361340f565b60208301905092915050565b5f602082019050919050565b5f61344b826133e6565b61345581856133f0565b935061346083613400565b805f5b83811015613490578151613477888261341e565b975061348283613435565b925050600181019050613463565b5085935050505092915050565b5f60a0820190506134b05f830188612661565b6134bd6020830187612867565b81810360408301526134cf8186613441565b90506134de60608301856127ac565b6134eb6080830184612661565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61352c826125bd565b9150613537836125bd565b925082613547576135466134f5565b5b828204905092915050565b5f6040820190506135655f830185612661565b61357260208301846127ac565b939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212209c48e9686822d6baa14ef1bbf5e5f6b1ad7739e335bf1ebc91d03006e313029164736f6c634300081a0033

Deployed Bytecode

0x608060405260043610610169575f3560e01c8063715018a6116100d0578063a9059cbb11610089578063dd62ed3e11610063578063dd62ed3e146104da578063ec1f3f6314610516578063f2fde38b1461053e578063f42938901461056657610170565b8063a9059cbb1461045e578063bf474bed1461049a578063c9567bf9146104c457610170565b8063715018a61461036457806377b54bad1461037a5780637d1db4a5146103b65780638da5cb5b146103e05780638f9a55c01461040a57806395d89b411461043457610170565b806323b872dd1161012257806323b872dd1461026e578063313ce567146102aa57806331acbe06146102d457806351bc3c85146102fc578063622565891461031257806370a082311461032857610170565b806306fdde0314610174578063095ea7b31461019e5780630faee56f146101da578063109daa99146102045780631694505e1461021a57806318160ddd1461024457610170565b3661017057005b5f80fd5b34801561017f575f80fd5b5061018861057c565b604051610195919061253f565b60405180910390f35b3480156101a9575f80fd5b506101c460048036038101906101bf91906125f0565b6105b9565b6040516101d19190612648565b60405180910390f35b3480156101e5575f80fd5b506101ee6105d6565b6040516101fb9190612670565b60405180910390f35b34801561020f575f80fd5b506102186105dc565b005b348015610225575f80fd5b5061022e610624565b60405161023b91906126e4565b60405180910390f35b34801561024f575f80fd5b50610258610649565b6040516102659190612670565b60405180910390f35b348015610279575f80fd5b50610294600480360381019061028f91906126fd565b61066d565b6040516102a19190612648565b60405180910390f35b3480156102b5575f80fd5b506102be610741565b6040516102cb9190612768565b60405180910390f35b3480156102df575f80fd5b506102fa60048036038101906102f59190612781565b610749565b005b348015610307575f80fd5b50610310610794565b005b34801561031d575f80fd5b5061032661082b565b005b348015610333575f80fd5b5061034e60048036038101906103499190612781565b6108d1565b60405161035b9190612670565b60405180910390f35b34801561036f575f80fd5b50610378610917565b005b348015610385575f80fd5b506103a0600480360381019061039b91906125f0565b61092a565b6040516103ad9190612648565b60405180910390f35b3480156103c1575f80fd5b506103ca610b4e565b6040516103d79190612670565b60405180910390f35b3480156103eb575f80fd5b506103f4610b54565b60405161040191906127bb565b60405180910390f35b348015610415575f80fd5b5061041e610b7b565b60405161042b9190612670565b60405180910390f35b34801561043f575f80fd5b50610448610b81565b604051610455919061253f565b60405180910390f35b348015610469575f80fd5b50610484600480360381019061047f91906125f0565b610bbe565b6040516104919190612648565b60405180910390f35b3480156104a5575f80fd5b506104ae610bdb565b6040516104bb9190612670565b60405180910390f35b3480156104cf575f80fd5b506104d8610be1565b005b3480156104e5575f80fd5b5061050060048036038101906104fb91906127d4565b611023565b60405161050d9190612670565b60405180910390f35b348015610521575f80fd5b5061053c60048036038101906105379190612812565b6110a5565b005b348015610549575f80fd5b50610564600480360381019061055f9190612781565b611131565b005b348015610571575f80fd5b5061057a6111b3565b005b60606040518060400160405280600b81526020017f506967656f6e20436f696e000000000000000000000000000000000000000000815250905090565b5f6105cc6105c5611264565b848461126b565b6001905092915050565b60115481565b6105e461142e565b5f600c819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f60405161061a9190612876565b60405180910390a1565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f6012600a61065891906129eb565b6461f313f8806106689190612a35565b905090565b5f6106798484846114ac565b61073684610685611264565b6107318560405180606001604052806028815260200161357a6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6106e8611264565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611e3f9092919063ffffffff16565b61126b565b600190509392505050565b5f6012905090565b61075161142e565b8060145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166107d4611264565b73ffffffffffffffffffffffffffffffffffffffff16146107f3575f80fd5b5f6107fd306108d1565b90505f8111156108115761081081611e93565b5b5f4790505f81111561082757610826816120fe565b5b5050565b61083361142e565b6012600a61084191906129eb565b6461f313f8806108519190612a35565b600e819055506012600a61086591906129eb565b6461f313f8806108759190612a35565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a6108aa91906129eb565b6461f313f8806108ba9190612a35565b6040516108c79190612670565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61091f61142e565b6109285f612166565b565b5f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661096b611264565b73ffffffffffffffffffffffffffffffffffffffff161461098a575f80fd5b5f8203610a71578273ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b81526004016109ca91906127bb565b602060405180830381865afa1580156109e5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a099190612a8a565b915060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f19350505050158015610a6f573d5f803e3d5ffd5b505b7fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f8383604051610aa2929190612ab5565b60405180910390a18273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846040518363ffffffff1660e01b8152600401610b06929190612afc565b6020604051808303815f875af1158015610b22573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b469190612b4d565b905092915050565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600681526020017f504947454f4e0000000000000000000000000000000000000000000000000000815250905090565b5f610bd1610bca611264565b84846114ac565b6001905092915050565b60105481565b610be961142e565b60148054906101000a900460ff1615610c37576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c2e90612bc2565b60405180910390fd5b610c803060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166012600a610c6b91906129eb565b6461f313f880610c7b9190612a35565b61126b565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cea573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d0e9190612bf4565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d94573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610db89190612bf4565b6040518363ffffffff1660e01b8152600401610dd5929190612c1f565b6020604051808303815f875af1158015610df1573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e159190612bf4565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610e9c306108d1565b5f8061dead426040518863ffffffff1660e01b8152600401610ec396959493929190612c46565b60606040518083038185885af1158015610edf573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610f049190612ca5565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610fa4929190612ab5565b6020604051808303815f875af1158015610fc0573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fe49190612b4d565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff02191690831515021790555043601781905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166110e5611264565b73ffffffffffffffffffffffffffffffffffffffff1614611104575f80fd5b600754811115801561111857506008548111155b611120575f80fd5b806007819055508060088190555050565b61113961142e565b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036111a7576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161119e90612d65565b60405180910390fd5b6111b081612166565b50565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166111f3611264565b73ffffffffffffffffffffffffffffffffffffffff1614611212575f80fd5b5f4790505f8111611258576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161124f90612df3565b60405180910390fd5b611261816120fe565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036112d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112d090612e81565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611347576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161133e90612f0f565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516114219190612670565b60405180910390a3505050565b611436611264565b73ffffffffffffffffffffffffffffffffffffffff16611454610b54565b73ffffffffffffffffffffffffffffffffffffffff16146114aa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a190612f77565b60405180910390fd5b565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361151a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161151190613005565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611588576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161157f90613093565b60405180910390fd5b5f81116115ca576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115c190613121565b60405180910390fd5b5f6115d3610b54565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156116415750611611610b54565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611b2c575f600d540361168e5761168b606461167d600954600d541161166a5760055461166e565b6007545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b5f600d5411156116c3576116c060646116b2600c548561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b6017544303611712576018600d5410611711576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161170890613189565b60405180910390fd5b5b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156117bb575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b801561180e575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561190657600e54821115611858576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161184f906131f1565b60405180910390fd5b600f5482611865856108d1565b61186f919061320f565b11156118b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118a79061328c565b60405180910390fd5b6118ec60646118de600954600d54116118cb576005546118cf565b6007545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b9050600d5f815480929190611900906132aa565b91905055505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561198e57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156119d2576119cf60646119c1600a54600d54116119ae576006546119b2565b6008545b8561222790919063ffffffff16565b61223c90919063ffffffff16565b90505b5f6119dc306108d1565b9050601460159054906101000a900460ff16158015611a47575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611a5f5750601460169054906101000a900460ff165b8015611a6c575060105481115b8015611a7b5750600b54600d54115b15611b2a57601654431115611a92575f6015819055505b600360155410611ad7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ace9061333b565b60405180910390fd5b611af4611aef84611aea84601154612251565b612251565b611e93565b5f4790505f811115611b0a57611b09476120fe565b5b60155f815480929190611b1c906132aa565b919050555043601681905550505b505b5f811115611c8e575f611b5c6064611b4e60018661222790919063ffffffff16565b61223c90919063ffffffff16565b90505f81118015611b6d5750808210155b15611b7d57611b7c8582612269565b5b80821115611c8c575f8183611b929190613359565b9050611be48160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611c829190612670565b60405180910390a3505b505b611cde8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124ba90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611d81611d3582846124ba90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611e2484866124ba90919063ffffffff16565b604051611e319190612670565b60405180910390a350505050565b5f838311158290611e86576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e7d919061253f565b60405180910390fd5b5082840390509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611eca57611ec961338c565b5b604051908082528060200260200182016040528015611ef85781602001602082028036833780820191505090505b50905030815f81518110611f0f57611f0e6133b9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611fb3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611fd79190612bf4565b81600181518110611feb57611fea6133b9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506120513060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff168461126b565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016120b395949392919061349d565b5f604051808303815f87803b1580156120ca575f80fd5b505af11580156120dc573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612162573d5f803e3d5ffd5b5050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f81836122349190612a35565b905092915050565b5f81836122499190613522565b905092915050565b5f81831161225f5782612261565b815b905092915050565b5f73ffffffffffffffffffffffffffffffffffffffff1660145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1603156124a15761232f8160015f60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546124a590919063ffffffff16565b60015f60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161240f9190612670565b60405180910390a360145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663665263f482846040518363ffffffff1660e01b8152600401612473929190613552565b5f604051808303815f87803b15801561248a575f80fd5b505af115801561249c573d5f803e3d5ffd5b505050505b5050565b5f81836124b2919061320f565b905092915050565b5f81836124c79190613359565b905092915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f612511826124cf565b61251b81856124d9565b935061252b8185602086016124e9565b612534816124f7565b840191505092915050565b5f6020820190508181035f8301526125578184612507565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61258c82612563565b9050919050565b61259c81612582565b81146125a6575f80fd5b50565b5f813590506125b781612593565b92915050565b5f819050919050565b6125cf816125bd565b81146125d9575f80fd5b50565b5f813590506125ea816125c6565b92915050565b5f80604083850312156126065761260561255f565b5b5f612613858286016125a9565b9250506020612624858286016125dc565b9150509250929050565b5f8115159050919050565b6126428161262e565b82525050565b5f60208201905061265b5f830184612639565b92915050565b61266a816125bd565b82525050565b5f6020820190506126835f830184612661565b92915050565b5f819050919050565b5f6126ac6126a76126a284612563565b612689565b612563565b9050919050565b5f6126bd82612692565b9050919050565b5f6126ce826126b3565b9050919050565b6126de816126c4565b82525050565b5f6020820190506126f75f8301846126d5565b92915050565b5f805f606084860312156127145761271361255f565b5b5f612721868287016125a9565b9350506020612732868287016125a9565b9250506040612743868287016125dc565b9150509250925092565b5f60ff82169050919050565b6127628161274d565b82525050565b5f60208201905061277b5f830184612759565b92915050565b5f602082840312156127965761279561255f565b5b5f6127a3848285016125a9565b91505092915050565b6127b581612582565b82525050565b5f6020820190506127ce5f8301846127ac565b92915050565b5f80604083850312156127ea576127e961255f565b5b5f6127f7858286016125a9565b9250506020612808858286016125a9565b9150509250929050565b5f602082840312156128275761282661255f565b5b5f612834848285016125dc565b91505092915050565b5f819050919050565b5f61286061285b6128568461283d565b612689565b6125bd565b9050919050565b61287081612846565b82525050565b5f6020820190506128895f830184612867565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612911578086048111156128ed576128ec61288f565b5b60018516156128fc5780820291505b808102905061290a856128bc565b94506128d1565b94509492505050565b5f8261292957600190506129e4565b81612936575f90506129e4565b816001811461294c576002811461295657612985565b60019150506129e4565b60ff8411156129685761296761288f565b5b8360020a91508482111561297f5761297e61288f565b5b506129e4565b5060208310610133831016604e8410600b84101617156129ba5782820a9050838111156129b5576129b461288f565b5b6129e4565b6129c784848460016128c8565b925090508184048111156129de576129dd61288f565b5b81810290505b9392505050565b5f6129f5826125bd565b9150612a008361274d565b9250612a2d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff848461291a565b905092915050565b5f612a3f826125bd565b9150612a4a836125bd565b9250828202612a58816125bd565b91508282048414831517612a6f57612a6e61288f565b5b5092915050565b5f81519050612a84816125c6565b92915050565b5f60208284031215612a9f57612a9e61255f565b5b5f612aac84828501612a76565b91505092915050565b5f604082019050612ac85f8301856127ac565b612ad56020830184612661565b9392505050565b5f612ae6826126b3565b9050919050565b612af681612adc565b82525050565b5f604082019050612b0f5f830185612aed565b612b1c6020830184612661565b9392505050565b612b2c8161262e565b8114612b36575f80fd5b50565b5f81519050612b4781612b23565b92915050565b5f60208284031215612b6257612b6161255f565b5b5f612b6f84828501612b39565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612bac6017836124d9565b9150612bb782612b78565b602082019050919050565b5f6020820190508181035f830152612bd981612ba0565b9050919050565b5f81519050612bee81612593565b92915050565b5f60208284031215612c0957612c0861255f565b5b5f612c1684828501612be0565b91505092915050565b5f604082019050612c325f8301856127ac565b612c3f60208301846127ac565b9392505050565b5f60c082019050612c595f8301896127ac565b612c666020830188612661565b612c736040830187612867565b612c806060830186612867565b612c8d60808301856127ac565b612c9a60a0830184612661565b979650505050505050565b5f805f60608486031215612cbc57612cbb61255f565b5b5f612cc986828701612a76565b9350506020612cda86828701612a76565b9250506040612ceb86828701612a76565b9150509250925092565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f612d4f6026836124d9565b9150612d5a82612cf5565b604082019050919050565b5f6020820190508181035f830152612d7c81612d43565b9050919050565b7f436f6e74726163742062616c616e6365206d75737420626520677265617465725f8201527f207468616e207a65726f00000000000000000000000000000000000000000000602082015250565b5f612ddd602a836124d9565b9150612de882612d83565b604082019050919050565b5f6020820190508181035f830152612e0a81612dd1565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612e6b6024836124d9565b9150612e7682612e11565b604082019050919050565b5f6020820190508181035f830152612e9881612e5f565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612ef96022836124d9565b9150612f0482612e9f565b604082019050919050565b5f6020820190508181035f830152612f2681612eed565b9050919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612f616020836124d9565b9150612f6c82612f2d565b602082019050919050565b5f6020820190508181035f830152612f8e81612f55565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612fef6025836124d9565b9150612ffa82612f95565b604082019050919050565b5f6020820190508181035f83015261301c81612fe3565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f61307d6023836124d9565b915061308882613023565b604082019050919050565b5f6020820190508181035f8301526130aa81613071565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61310b6029836124d9565b9150613116826130b1565b604082019050919050565b5f6020820190508181035f830152613138816130ff565b9050919050565b7f457863656564732062757973206f6e2074686520666972737420626c6f636b2e5f82015250565b5f6131736020836124d9565b915061317e8261313f565b602082019050919050565b5f6020820190508181035f8301526131a081613167565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6131db6019836124d9565b91506131e6826131a7565b602082019050919050565b5f6020820190508181035f830152613208816131cf565b9050919050565b5f613219826125bd565b9150613224836125bd565b925082820190508082111561323c5761323b61288f565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f613276601a836124d9565b915061328182613242565b602082019050919050565b5f6020820190508181035f8301526132a38161326a565b9050919050565b5f6132b4826125bd565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036132e6576132e561288f565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f6133256017836124d9565b9150613330826132f1565b602082019050919050565b5f6020820190508181035f83015261335281613319565b9050919050565b5f613363826125bd565b915061336e836125bd565b92508282039050818111156133865761338561288f565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61341881612582565b82525050565b5f613429838361340f565b60208301905092915050565b5f602082019050919050565b5f61344b826133e6565b61345581856133f0565b935061346083613400565b805f5b83811015613490578151613477888261341e565b975061348283613435565b925050600181019050613463565b5085935050505092915050565b5f60a0820190506134b05f830188612661565b6134bd6020830187612867565b81810360408301526134cf8186613441565b90506134de60608301856127ac565b6134eb6080830184612661565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61352c826125bd565b9150613537836125bd565b925082613547576135466134f5565b5b828204905092915050565b5f6040820190506135655f830185612661565b61357260208301846127ac565b939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212209c48e9686822d6baa14ef1bbf5e5f6b1ad7739e335bf1ebc91d03006e313029164736f6c634300081a0033

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.