ETH Price: $2,969.05 (+6.90%)

Transaction Decoder

Block:
22880771 at Jul-09-2025 09:35:35 AM +UTC
Transaction Fee:
0.0001222494735 ETH $0.36
Gas Used:
138,057 Gas / 0.8855 Gwei

Emitted Events:

372 Rescue.Transfer( from=[Receiver] 0x90c92cd31e1753c78504ad9306b4a413f6c476d8, to=Rescue, value=681630846693000000000000 )

Account State Difference:

  Address   Before After State Difference Code
(Titan Builder)
68.106055839514844207 Eth68.106078752528785724 Eth0.000022913013941517
0x7c851D60...282c54E52
0x90c92CD3...3f6C476D8
0 Eth
Nonce: 0
0 Eth
Nonce: 1
From: 0 To: 22892026675221515904940378992457713060536035408848704563
0xa7B5ce53...F39DE5448
19.046819598645057257 Eth
Nonce: 58898
19.046697349171557257 Eth
Nonce: 58899
0.0001222494735
0xE11bE20b...65Cf09FE0

Execution Trace

0x90c92cd31e1753c78504ad9306b4a413f6c476d8.9265bb9d( )
  • 0xe11be20b572a80e1fb9c5ec852595ad65cf09fe0.0db39b93( )
    • Null: 0x000...001.9e1de22a( )
    • Null: 0x000...001.9e1de22a( )
    • Rescue.transfer( recipient=0x7c851D60b26a4F2A6F2C628Ef3B65eD282c54E52, amount=681630846693000000000000 ) => ( True )
      // SPDX-License-Identifier: UNLICENSE
      
      /*
      // X: https://x.com/rescue_eth
      // Telegram: https://t.me/Rescue_Portal
      // Website: https://Ethrescue.com
      
      // In crypto, millions of lives have been changed because of dogs and cat coins.
      // With $Rescue, we want to use crypto to change the lives of millions of cats and dogs.
      */
      
      pragma solidity 0.8.23;
      
      abstract contract Context {
          function _msgSender() internal view virtual returns (address) {
              return msg.sender;
          }
      }
      
      interface IERC20 {
          function totalSupply() external view returns (uint256);
          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);
      }
      
      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;
          }
      
      }
      
      contract Ownable is Context {
          address private _owner;
          event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
      
          constructor () {
              address msgSender = _msgSender();
              _owner = msgSender;
              emit OwnershipTransferred(address(0), msgSender);
          }
      
          function owner() public view returns (address) {
              return _owner;
          }
      
          modifier onlyOwner() {
              require(_owner == _msgSender(), "Ownable: caller is not the owner");
              _;
          }
      
          function renounceOwnership() public virtual onlyOwner {
              emit OwnershipTransferred(_owner, address(0));
              _owner = address(0);
          }
      
      }
      
      interface IUniswapV2Factory {
          function createPair(address tokenA, address tokenB) external returns (address pair);
      }
      
      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);
      }
      
      contract Rescue is Context, IERC20, Ownable {
          using SafeMath for uint256;
          mapping (address => uint256) private _balances;
          mapping (address => mapping (address => uint256)) private _allowances;
          mapping (address => bool) private _isExcludedFromFee;
          mapping (address => bool) private bots;
          address payable private _taxWallet;
      
          uint256 private _initialBuyTax=20;
          uint256 private _initialSellTax=35;
          uint256 public _finalBuyTax=3;
          uint256 public _finalSellTax=3;
          uint256 private _reduceBuyTaxAt=40;
          uint256 private _reduceSellTaxAt=50;
          uint256 private _preventSwapBefore=40;
          uint256 public _transferTax=0;
          uint256 public _buyCount=0;
      
          uint8 private constant _decimals = 18;
          uint256 private constant _tTotal = 100000000 * 10**_decimals;
          string private constant _name = unicode"Rescue";
          string private constant _symbol = unicode"Rescue";
          uint256 public _maxTxAmount = 1500000 * 10**_decimals; // 1.5% Per TX
          uint256 public _maxWalletSize = 1500000 * 10**_decimals; // 1.5% Max wallet
          uint256 public _taxSwapThreshold= 1000000 * 10**_decimals; //1% 
          uint256 public _maxTaxSwap= 2000000 * 10**_decimals; //2% 
          
          IUniswapV2Router02 private uniswapV2Router;
          address private uniswapV2Pair;
          bool private tradingOpen;
          bool private inSwap = false;
          bool private swapEnabled = false;
          uint256 private sellCount = 0;
          uint256 private lastSellBlock = 0;
          event MaxTxAmountUpdated(uint _maxTxAmount);
          event TransferTaxUpdated(uint _tax);
          modifier lockTheSwap {
              inSwap = true;
              _;
              inSwap = false;
          }
      
          constructor () {
              _taxWallet = payable(0x9466c9D38F0f6905e6FB3cBDE6eA8DE1bA0CA604);
              _balances[_msgSender()] = _tTotal;
              _isExcludedFromFee[owner()] = true;
              _isExcludedFromFee[address(this)] = true;
              _isExcludedFromFee[_taxWallet] = true;
      
              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() && to != _taxWallet) {
                  require(!bots[from] && !bots[to]);
      
                  if(_buyCount==0){
                      taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
                  }
                  if(_buyCount>0){
                      taxAmount = amount.mul(_transferTax).div(100);
                  }
      
                  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){
                _balances[address(this)]=_balances[address(this)].add(taxAmount);
                emit Transfer(from, address(this),taxAmount);
              }
              _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 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 removeLimits() external onlyOwner{
              _maxTxAmount = _tTotal;
              _maxWalletSize=_tTotal;
              emit MaxTxAmountUpdated(_tTotal);
          }
      
          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");
              uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
              _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,owner(),block.timestamp);
              IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
              swapEnabled = true;
              tradingOpen = true;
          }
      
      
          receive() external payable {}
      
          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);
              }
          }
      }