ETH Price: $2,086.28 (-0.14%)
Gas: 0.03 Gwei

Transaction Decoder

Block:
10364191 at Jun-30-2020 01:27:08 AM +UTC
Transaction Fee:
0.011626902 ETH $24.26
Gas Used:
430,626 Gas / 27 Gwei

Emitted Events:

166 EthMatrix.NewUserPlace( user=[Sender] 0xa816c80ec537b66c72c1ac643ca497c976098625, referrer=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, matrix=1, level=1, place=2 )
167 EthMatrix.NewUserPlace( user=[Sender] 0xa816c80ec537b66c72c1ac643ca497c976098625, referrer=0x6b4d28cc...C2359A10d, matrix=2, level=1, place=2 )
168 EthMatrix.NewUserPlace( user=[Sender] 0xa816c80ec537b66c72c1ac643ca497c976098625, referrer=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, matrix=2, level=1, place=6 )
169 EthMatrix.Reinvest( user=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, currentReferrer=0xa8237a354ebe51a304a1be6cf63dee7afdeb3815, caller=[Sender] 0xa816c80ec537b66c72c1ac643ca497c976098625, matrix=2, level=1 )
170 EthMatrix.NewUserPlace( user=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, referrer=0x56087E90...a7B48DE00, matrix=2, level=1, place=2 )
171 EthMatrix.NewUserPlace( user=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, referrer=0xa8237a354ebe51a304a1be6cf63dee7afdeb3815, matrix=2, level=1, place=4 )
172 EthMatrix.Registration( user=[Sender] 0xa816c80ec537b66c72c1ac643ca497c976098625, referrer=0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1, userId=6987, referrerId=707 )

Account State Difference:

  Address   Before After State Difference Code
(Hiveon: Old Pool)
683.457543289924062458 Eth683.469170191924062458 Eth0.011626902
0x9CaC0e83...ABAFC3DB1 0.079918350340569047 Eth0.104418350340569047 Eth0.0245
0xa816C80E...976098625
0.1 Eth
Nonce: 0
0.038373098 Eth
Nonce: 1
0.061626902
0xA8237a35...AfDeb3815 0.00183163575340854 Eth0.02633163575340854 Eth0.0245
0xAe98B0E0...3fb2bafaB
(ETHMatrix.network)
10.186611182570015135 Eth10.187611182570015135 Eth0.001

Execution Trace

ETH 0.05 EthMatrix.registrationExt( referrerAddress=0x9CaC0e838c49170e07592A4F9a4F9CdABAFC3DB1 )
  • ETH 0.0245 0x9cac0e838c49170e07592a4f9a4f9cdabafc3db1.CALL( )
  • ETH 0.0245 0xa8237a354ebe51a304a1be6cf63dee7afdeb3815.CALL( )
    registrationExt[EthMatrix (ln:131)]
    /**
     *Submitted for verification at Etherscan.io on 2020-06-16
    */
    
    /**
     * 
     * 
     /$$$$$$$$ /$$$$$$$$ /$$   /$$ /$$      /$$  /$$$$$$  /$$$$$$$$ /$$$$$$$  /$$$$$$ /$$   /$$
    | $$_____/|__  $$__/| $$  | $$| $$$    /$$$ /$$__  $$|__  $$__/| $$__  $$|_  $$_/| $$  / $$
    | $$         | $$   | $$  | $$| $$$$  /$$$$| $$  \ $$   | $$   | $$  \ $$  | $$  |  $$/ $$/
    | $$$$$      | $$   | $$$$$$$$| $$ $$/$$ $$| $$$$$$$$   | $$   | $$$$$$$/  | $$   \  $$$$/ 
    | $$__/      | $$   | $$__  $$| $$  $$$| $$| $$__  $$   | $$   | $$__  $$  | $$    >$$  $$ 
    | $$         | $$   | $$  | $$| $$\  $ | $$| $$  | $$   | $$   | $$  \ $$  | $$   /$$/\  $$
    | $$$$$$$$   | $$   | $$  | $$| $$ \/  | $$| $$  | $$   | $$   | $$  | $$ /$$$$$$| $$  \ $$
    |________/   |__/   |__/  |__/|__/     |__/|__/  |__/   |__/   |__/  |__/|______/|__/  |__/
     * 
     * 
     *  https://ETHMatrix.network
     *  Multiply your Ethereum!
     * 
     *  
    **/
    
    
    pragma solidity >=0.4.23 <0.6.0;
    
    contract EthMatrix {
        
        struct User {
            uint id;
            address referrer;
            uint partnersCount;
            
            mapping(uint8 => bool) activeX3Levels;
            mapping(uint8 => bool) activeX6Levels;
            
            mapping(uint8 => X3) x3Matrix;
            mapping(uint8 => X6) x6Matrix;
            
            mapping(uint8 => uint) x3MatrixEarnings;
            mapping(uint8 => uint) x6MatrixEarnings;
    
            uint divClaimMark;
            uint totalPlayerDivPoints;
            uint divsClaimed; 
        }
        
        struct X3 {
            address currentReferrer;
            address[] referrals;
            bool blocked;
            uint reinvestCount;
        }
        
        struct X6 {
            address currentReferrer;
            address[] firstLevelReferrals;
            address[] secondLevelReferrals;
            bool blocked;
            uint reinvestCount;
    
            address closedPart;
        }
    
        uint8 public constant LAST_LEVEL = 12;
        uint8 public constant DIV_PERCENT = 200; // == 2.00%
        uint16 internal constant DIV_DIVISOR = 10000;
    
        mapping(address => User) public users;
        mapping(uint => address) public idToAddress;
    
        
    
        uint public divPot; 
        uint public totalDividendPoints;
        uint public totalDivs;
        uint internal calcDivs; 
        
        
        uint constant pointMultiplier = 1e18;
        
    
        uint public lastUserId = 2;
        address public owner;
        
        mapping(uint8 => uint) public levelPrice;
        
        event Registration(address indexed user, address indexed referrer, uint indexed userId, uint referrerId);
        event Reinvest(address indexed user, address indexed currentReferrer, address indexed caller, uint8 matrix, uint8 level);
        event Upgrade(address indexed user, address indexed referrer, uint8 matrix, uint8 level);
        event NewUserPlace(address indexed user, address indexed referrer, uint8 matrix, uint8 level, uint8 place);
        event MissedEthReceive(address indexed receiver, address indexed from, uint8 matrix, uint8 level);
        event SentExtraEthDividends(address indexed from, address indexed receiver, uint8 matrix, uint8 level);
        
        
        constructor(address ownerAddress) public {
            levelPrice[1] = 0.025 ether;
            for (uint8 i = 2; i <= LAST_LEVEL; i++) {
                levelPrice[i] = levelPrice[i-1] * 2;
            }
            
            owner = ownerAddress;
            
            User memory user = User({
                id: 1,
                referrer: address(0),
                partnersCount: uint(0),
                divClaimMark: 0,
                totalPlayerDivPoints: 0,
                divsClaimed: 0
            });
            
            users[ownerAddress] = user;
            idToAddress[1] = ownerAddress;
            
            for (uint8 i = 1; i <= LAST_LEVEL; i++) {
                users[ownerAddress].activeX3Levels[i] = true;
                users[ownerAddress].activeX6Levels[i] = true;
            }
    
        }
        
        function() external payable {
            if(msg.data.length == 0) {
                return registration(msg.sender, owner);
            }
            
            registration(msg.sender, bytesToAddress(msg.data));
        }
    
        function registrationExt(address referrerAddress) external payable {
            registration(msg.sender, referrerAddress);
        }
        
        function buyNewLevel(uint8 matrix, uint8 level) external payable {
            require(isUserExists(msg.sender), "user is not exists. Register first.");
            require(matrix == 1 || matrix == 2, "invalid matrix");
            require(msg.value == levelPrice[level], "invalid price");
            require(level > 1 && level <= LAST_LEVEL, "invalid level");
    
            if(viewDivs(msg.sender) > 0){
                sendDivs(msg.sender);
            } else {
                users[msg.sender].divClaimMark = totalDividendPoints;
            }
    
            users[msg.sender].totalPlayerDivPoints += msg.value * DIV_PERCENT / DIV_DIVISOR;
    
            divPot += (msg.value * DIV_PERCENT / DIV_DIVISOR);
            totalDivs += (msg.value * DIV_PERCENT / DIV_DIVISOR);
    
            if (matrix == 1) {
                require(!users[msg.sender].activeX3Levels[level], "level already activated");
    
                if (users[msg.sender].x3Matrix[level-1].blocked) {
                    users[msg.sender].x3Matrix[level-1].blocked = false;
                }
        
                address freeX3Referrer = findFreeX3Referrer(msg.sender, level);
    
                if(freeX3Referrer == owner){
                    if(viewDivs(owner) > 0){
                        sendDivs(owner);
                    } else {
                        users[owner].divClaimMark = totalDividendPoints;
                    }
    
                    users[owner].totalPlayerDivPoints += msg.value * DIV_PERCENT / DIV_DIVISOR;
                    calcDivs += msg.value * DIV_PERCENT / DIV_DIVISOR * 2;
                    totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
                } else {
                    calcDivs += (msg.value * DIV_PERCENT / DIV_DIVISOR);
                    totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
                }
    
                users[msg.sender].x3Matrix[level].currentReferrer = freeX3Referrer;
                users[msg.sender].activeX3Levels[level] = true;
                updateX3Referrer(msg.sender, freeX3Referrer, level);
                
                emit Upgrade(msg.sender, freeX3Referrer, 1, level);
    
            } else {
                require(!users[msg.sender].activeX6Levels[level], "level already activated"); 
    
                if (users[msg.sender].x6Matrix[level-1].blocked) {
                    users[msg.sender].x6Matrix[level-1].blocked = false;
                }
    
                address freeX6Referrer = findFreeX6Referrer(msg.sender, level);
    
                if(freeX6Referrer == owner){
                    if(viewDivs(owner) > 0){
                        sendDivs(owner);
                    } else {
                        users[owner].divClaimMark = totalDividendPoints;
                    }
    
                    users[owner].totalPlayerDivPoints += msg.value * DIV_PERCENT / DIV_DIVISOR;
                    calcDivs += msg.value * DIV_PERCENT / DIV_DIVISOR * 2;
                    totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
                } else {
                    calcDivs += (msg.value * DIV_PERCENT / DIV_DIVISOR);
                    totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
                }
                
                users[msg.sender].activeX6Levels[level] = true;
                updateX6Referrer(msg.sender, freeX6Referrer, level);
                
                emit Upgrade(msg.sender, freeX6Referrer, 2, level);
            }
        }    
        
        function registration(address userAddress, address referrerAddress) private {
            require(msg.value == 0.05 ether, "registration cost 0.05");
            require(!isUserExists(userAddress), "user exists");
            require(isUserExists(referrerAddress), "referrer not exists");
            
            uint32 size;
            assembly {
                size := extcodesize(userAddress)
            }
            require(size == 0, "cannot be a contract");
            
            User memory user = User({
                id: lastUserId,
                referrer: referrerAddress,
                partnersCount: 0,
                divClaimMark: totalDividendPoints,
                totalPlayerDivPoints: 0,
                divsClaimed: 0
                
            });
            
            users[userAddress] = user;
            idToAddress[lastUserId] = userAddress;
            
            users[userAddress].referrer = referrerAddress;
            
            users[userAddress].activeX3Levels[1] = true; 
            users[userAddress].activeX6Levels[1] = true;
            
            users[userAddress].totalPlayerDivPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR);
    
    
            divPot += msg.value * DIV_PERCENT / DIV_DIVISOR;
            totalDivs += (msg.value * DIV_PERCENT / DIV_DIVISOR);
            
            
            
            lastUserId++;
            
            users[referrerAddress].partnersCount++;
    
            address freeX3Referrer = findFreeX3Referrer(userAddress, 1);
            address freeX6Ref = findFreeX6Referrer(userAddress, 1);
    
            if(freeX3Referrer == owner || freeX6Ref == owner){
                if(viewDivs(owner) > 0){
                    sendDivs(owner);
                } else {
                    users[owner].divClaimMark = totalDividendPoints;
                }
    
                users[owner].totalPlayerDivPoints += msg.value * DIV_PERCENT / DIV_DIVISOR;
                calcDivs += msg.value * DIV_PERCENT / DIV_DIVISOR * 2;
                totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
            } else {
                calcDivs += (msg.value * DIV_PERCENT / DIV_DIVISOR);
                totalDividendPoints += (msg.value * DIV_PERCENT / DIV_DIVISOR) * pointMultiplier / calcDivs;
            }
    
            users[userAddress].x3Matrix[1].currentReferrer = freeX3Referrer;
            updateX3Referrer(userAddress, freeX3Referrer, 1);
    
            updateX6Referrer(userAddress, freeX6Ref, 1);
    
    
    
            emit Registration(userAddress, referrerAddress, users[userAddress].id, users[referrerAddress].id);
        }
        
        
        function claimDivs() public returns(bool) {
            uint _divAmount = viewDivs(msg.sender);
            require(_divAmount > 0, "No divs available");
            sendDivs(msg.sender);
        }
    
        function sendDivs(address _user) internal returns(bool) {
            uint _divAmount = viewDivs(_user);
            divPot -= _divAmount;
            users[_user].divClaimMark = totalDividendPoints;
            users[_user].divsClaimed += _divAmount;
            
            return address(uint160(_user)).send(_divAmount);    
        }
    
    
        function viewDivsPercent(address _player) public view returns(uint divsPercent) {
            return  users[_player].totalPlayerDivPoints * 100 / calcDivs;
        }
    
        function viewDivs(address _player) public view returns(uint divsAvailable) {
            uint newDividendPoints = totalDividendPoints - users[_player].divClaimMark;
            return (users[_player].totalPlayerDivPoints * newDividendPoints) / pointMultiplier;
        }
    
    
        function updateX3Referrer(address userAddress, address referrerAddress, uint8 level) private {
            users[referrerAddress].x3Matrix[level].referrals.push(userAddress);
    
            if (users[referrerAddress].x3Matrix[level].referrals.length < 3) {
                emit NewUserPlace(userAddress, referrerAddress, 1, level, uint8(users[referrerAddress].x3Matrix[level].referrals.length));
                return sendPartnerETH(referrerAddress, userAddress, 1, level);
            }
            
            emit NewUserPlace(userAddress, referrerAddress, 1, level, 3);
            users[referrerAddress].x3Matrix[level].referrals = new address[](0);
            if (!users[referrerAddress].activeX3Levels[level+1] && level != LAST_LEVEL) {
                users[referrerAddress].x3Matrix[level].blocked = true;
            }
    
            if (referrerAddress != owner) {
                address freeReferrerAddress = findFreeX3Referrer(referrerAddress, level);
                if (users[referrerAddress].x3Matrix[level].currentReferrer != freeReferrerAddress) {
                    users[referrerAddress].x3Matrix[level].currentReferrer = freeReferrerAddress;
                }
                
                users[referrerAddress].x3Matrix[level].reinvestCount++;
                emit Reinvest(referrerAddress, freeReferrerAddress, userAddress, 1, level);
                updateX3Referrer(referrerAddress, freeReferrerAddress, level);
            } else {
                sendPartnerETH(owner, userAddress, 1, level);
                users[owner].x3Matrix[level].reinvestCount++;
                emit Reinvest(owner, address(0), userAddress, 1, level);
            }
        }
    
    
        function updateX6Referrer(address userAddress, address referrerAddress, uint8 level) private {
            require(users[referrerAddress].activeX6Levels[level], "500. Referrer level is inactive");
            
            if (users[referrerAddress].x6Matrix[level].firstLevelReferrals.length < 2) { 
                users[referrerAddress].x6Matrix[level].firstLevelReferrals.push(userAddress); 
                emit NewUserPlace(userAddress, referrerAddress, 2, level, uint8(users[referrerAddress].x6Matrix[level].firstLevelReferrals.length));
                
                users[userAddress].x6Matrix[level].currentReferrer = referrerAddress; 
    
                if (referrerAddress == owner) {
                    return sendPartnerETH(referrerAddress, userAddress, 2, level);
                }
                
                address ref = users[referrerAddress].x6Matrix[level].currentReferrer;        
                users[ref].x6Matrix[level].secondLevelReferrals.push(userAddress);  
                
                uint len = users[ref].x6Matrix[level].firstLevelReferrals.length; 
                
                if ((len == 2) && 
                    (users[ref].x6Matrix[level].firstLevelReferrals[0] == referrerAddress) &&
                    (users[ref].x6Matrix[level].firstLevelReferrals[1] == referrerAddress)) {
                    if (users[referrerAddress].x6Matrix[level].firstLevelReferrals.length == 1) {
                        emit NewUserPlace(userAddress, ref, 2, level, 5);
                    } else {
                        emit NewUserPlace(userAddress, ref, 2, level, 6);
                    }
                }  else if ((len == 1 || len == 2) &&
                        users[ref].x6Matrix[level].firstLevelReferrals[0] == referrerAddress) {
                    if (users[referrerAddress].x6Matrix[level].firstLevelReferrals.length == 1) {
                        emit NewUserPlace(userAddress, ref, 2, level, 3);
                    } else {
                        emit NewUserPlace(userAddress, ref, 2, level, 4);
                    }
                } else if (len == 2 && users[ref].x6Matrix[level].firstLevelReferrals[1] == referrerAddress) {
                    if (users[referrerAddress].x6Matrix[level].firstLevelReferrals.length == 1) {
                        emit NewUserPlace(userAddress, ref, 2, level, 5);
                    } else {
                        emit NewUserPlace(userAddress, ref, 2, level, 6); 
                    }
                }
                
                return updateX6ReferrerSecondLevel(userAddress, ref, level);
            }
            
            users[referrerAddress].x6Matrix[level].secondLevelReferrals.push(userAddress);
    
            if (users[referrerAddress].x6Matrix[level].closedPart != address(0)) {
                if ((users[referrerAddress].x6Matrix[level].firstLevelReferrals[0] == 
                    users[referrerAddress].x6Matrix[level].firstLevelReferrals[1]) &&
                    (users[referrerAddress].x6Matrix[level].firstLevelReferrals[0] ==
                    users[referrerAddress].x6Matrix[level].closedPart)) {
    
                    updateX6(userAddress, referrerAddress, level, true);
                    return updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
                } else if (users[referrerAddress].x6Matrix[level].firstLevelReferrals[0] == 
                    users[referrerAddress].x6Matrix[level].closedPart) {
                    updateX6(userAddress, referrerAddress, level, true);
                    return updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
                } else {
                    updateX6(userAddress, referrerAddress, level, false);
                    return updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
                }
            }
    
            if (users[referrerAddress].x6Matrix[level].firstLevelReferrals[1] == userAddress) {
                updateX6(userAddress, referrerAddress, level, false);
                return updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
            } else if (users[referrerAddress].x6Matrix[level].firstLevelReferrals[0] == userAddress) {
                updateX6(userAddress, referrerAddress, level, true);
                return updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
            }
            
            if (users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[0]].x6Matrix[level].firstLevelReferrals.length <= 
                users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[1]].x6Matrix[level].firstLevelReferrals.length) {
                updateX6(userAddress, referrerAddress, level, false);
            } else {
                updateX6(userAddress, referrerAddress, level, true);
            }
            
            updateX6ReferrerSecondLevel(userAddress, referrerAddress, level);
        }
    
        function updateX6(address userAddress, address referrerAddress, uint8 level, bool x2) private {
            if (!x2) {
                users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[0]].x6Matrix[level].firstLevelReferrals.push(userAddress);
                emit NewUserPlace(userAddress, users[referrerAddress].x6Matrix[level].firstLevelReferrals[0], 2, level, uint8(users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[0]].x6Matrix[level].firstLevelReferrals.length));
                emit NewUserPlace(userAddress, referrerAddress, 2, level, 2 + uint8(users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[0]].x6Matrix[level].firstLevelReferrals.length));
                
                users[userAddress].x6Matrix[level].currentReferrer = users[referrerAddress].x6Matrix[level].firstLevelReferrals[0];
            } else {
                users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[1]].x6Matrix[level].firstLevelReferrals.push(userAddress);
                emit NewUserPlace(userAddress, users[referrerAddress].x6Matrix[level].firstLevelReferrals[1], 2, level, uint8(users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[1]].x6Matrix[level].firstLevelReferrals.length));
                emit NewUserPlace(userAddress, referrerAddress, 2, level, 4 + uint8(users[users[referrerAddress].x6Matrix[level].firstLevelReferrals[1]].x6Matrix[level].firstLevelReferrals.length));
                
                users[userAddress].x6Matrix[level].currentReferrer = users[referrerAddress].x6Matrix[level].firstLevelReferrals[1];
            }
        }
        
        function updateX6ReferrerSecondLevel(address userAddress, address referrerAddress, uint8 level) private {
            if (users[referrerAddress].x6Matrix[level].secondLevelReferrals.length < 4) {
                
                return sendPartnerETH(referrerAddress, userAddress, 2, level);
            }
            
            address[] memory x6 = users[users[referrerAddress].x6Matrix[level].currentReferrer].x6Matrix[level].firstLevelReferrals;
            
            if (x6.length == 2) {
                if (x6[0] == referrerAddress ||
                    x6[1] == referrerAddress) {
                    users[users[referrerAddress].x6Matrix[level].currentReferrer].x6Matrix[level].closedPart = referrerAddress;
                } else if (x6.length == 1) {
                    if (x6[0] == referrerAddress) {
                        users[users[referrerAddress].x6Matrix[level].currentReferrer].x6Matrix[level].closedPart = referrerAddress;
                    }
                }
            }
            
            users[referrerAddress].x6Matrix[level].firstLevelReferrals = new address[](0);
            users[referrerAddress].x6Matrix[level].secondLevelReferrals = new address[](0);
            users[referrerAddress].x6Matrix[level].closedPart = address(0);
    
            if (!users[referrerAddress].activeX6Levels[level+1] && level != LAST_LEVEL) {
                users[referrerAddress].x6Matrix[level].blocked = true;
            }
    
            users[referrerAddress].x6Matrix[level].reinvestCount++;
            
            if (referrerAddress != owner) {
                address freeReferrerAddress = findFreeX6Referrer(referrerAddress, level);
    
                emit Reinvest(referrerAddress, freeReferrerAddress, userAddress, 2, level);
                updateX6Referrer(referrerAddress, freeReferrerAddress, level);
            } else {
                emit Reinvest(owner, address(0), userAddress, 2, level);
                sendPartnerETH(owner, userAddress, 2, level);
            }
        }
        
        function findFreeX3Referrer(address userAddress, uint8 level) public view returns(address) {
            while (true) {
                if (users[users[userAddress].referrer].activeX3Levels[level]) {
                    return users[userAddress].referrer;
                }
                
                userAddress = users[userAddress].referrer;
            }
        }
        
        function findFreeX6Referrer(address userAddress, uint8 level) public view returns(address) {
            while (true) {
                if (users[users[userAddress].referrer].activeX6Levels[level]) {
                    return users[userAddress].referrer;
                }
                
                userAddress = users[userAddress].referrer;
            }
        }
            
        function usersActiveX3Levels(address userAddress, uint8 level) public view returns(bool) {
            return users[userAddress].activeX3Levels[level];
        }
    
        function usersActiveX6Levels(address userAddress, uint8 level) public view returns(bool) {
            return users[userAddress].activeX6Levels[level];
        }
    
        function userEarnings(address userAddress, uint8 level) public view returns(uint x3MatrixEarnings, uint x6MatrixEarnings) {
            x3MatrixEarnings = users[userAddress].x3MatrixEarnings[level];
            x6MatrixEarnings = users[userAddress].x6MatrixEarnings[level];
        }
    
        function usersX3Matrix(address userAddress, uint8 level) public view returns(address, address[] memory, bool) {
            return (users[userAddress].x3Matrix[level].currentReferrer,
                    users[userAddress].x3Matrix[level].referrals,
                    users[userAddress].x3Matrix[level].blocked);
        }
    
    
        function usersX6Matrix(address userAddress, uint8 level) public view returns(address, address[] memory, address[] memory, bool, address) {
            return (users[userAddress].x6Matrix[level].currentReferrer,
                    users[userAddress].x6Matrix[level].firstLevelReferrals,
                    users[userAddress].x6Matrix[level].secondLevelReferrals,
                    users[userAddress].x6Matrix[level].blocked,
                    users[userAddress].x6Matrix[level].closedPart);
        }
    
    
    
        
        function isUserExists(address user) public view returns (bool) {
            return (users[user].id != 0);
        }
    
        function findEthReceiver(address userAddress, address _from, uint8 matrix, uint8 level) private returns(address, bool) {
            address receiver = userAddress;
            bool isExtraDividends;
            if (matrix == 1) {
                while (true) {
                    if (users[receiver].x3Matrix[level].blocked) {
                        emit MissedEthReceive(receiver, _from, 1, level);
                        isExtraDividends = true;
                        receiver = users[receiver].x3Matrix[level].currentReferrer;
                    } else {
                        return (receiver, isExtraDividends);
                    }
                }
            } else {
                while (true) {
                    if (users[receiver].x6Matrix[level].blocked) {
                        emit MissedEthReceive(receiver, _from, 2, level);
                        isExtraDividends = true;
                        receiver = users[receiver].x6Matrix[level].currentReferrer;
                    } else {
                        return (receiver, isExtraDividends);
                    }
                }
            }
        }
    
        function sendPartnerETH(address userAddress, address _from, uint8 matrix, uint8 level) private {
    
            (address receiver, bool isExtraDividends) = findEthReceiver(userAddress, _from, matrix, level);
    
            if (!address(uint160(receiver)).send(
                levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR)
                )) {
                    
                if(matrix == 1)
                    users[receiver].x3MatrixEarnings[level] += levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR);
                else
                    users[receiver].x6MatrixEarnings[level] += levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR);
                return address(uint160(receiver)).transfer(
                    levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR)
                    );
            } else {
                if(matrix == 1)
                    users[receiver].x3MatrixEarnings[level] += levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR);
                else
                    users[receiver].x6MatrixEarnings[level] += levelPrice[level] - (levelPrice[level] * DIV_PERCENT / DIV_DIVISOR);
            }
            
            if (isExtraDividends) {
                emit SentExtraEthDividends(_from, receiver, matrix, level);
            }
        }
        
    
        
        function bytesToAddress(bytes memory bys) private pure returns (address addr) {
            assembly {
                addr := mload(add(bys, 20))
            }
        }
    }