Transaction Hash:
Block:
20375748 at Jul-24-2024 10:16:59 AM +UTC
Transaction Fee:
0.000190150771223137 ETH
$0.43
Gas Used:
46,279 Gas / 4.108791703 Gwei
Emitted Events:
| 339 |
UmToken.Approval( owner=[Sender] 0x3bd9124e9057c7acfa8f88ea2eef375ba52beda4, spender=0x00000000...43aC78BA3, value=500000000000000000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
| 0x3Bd9124e...ba52BeDA4 |
0.027523137043226536 Eth
Nonce: 4
|
0.027332986272003399 Eth
Nonce: 5
| 0.000190150771223137 | ||
| 0x7B198793...005cCb73B | |||||
|
0x95222290...5CC4BAfe5
Miner
| (beaverbuild) | 18.684340942221963187 Eth | 18.684382417932050385 Eth | 0.000041475710087198 |
Execution Trace
UmToken.approve( spender=0x000000000022D473030F116dDEE9F6B43aC78BA3, amount=500000000000000000000000 ) => ( True )
approve[UmToken (ln:151)]
_approve[UmToken (ln:152)]Approval[UmToken (ln:149)]
_msgSender[UmToken (ln:152)]
// SPDX-License-Identifier: SEE LICENSE IN LICENSE
pragma solidity ^0.8.20;
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB)
external
returns (address pair);
}
interface IUniswapV2Router02 {
function factory() external pure returns (address);
function WETH() external pure returns (address);
function swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
function addLiquidity(
address tokenA,
address tokenB,
uint256 amountADesired,
uint256 amountBDesired,
uint256 amountAMin,
uint256 amountBMin,
address to,
uint256 deadline
) external
returns (
uint256 amountA,
uint256 amountB,
uint256 liquidity
);
}
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
abstract contract Ownable is Context {
address private _owner;
error OwnableUnauthorizedAccount(address account);
error OwnableInvalidOwner(address owner);
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor(address initialOwner) {
if (initialOwner == address(0)) {
revert OwnableInvalidOwner(address(0));
}
_transferOwnership(initialOwner);
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
if (owner() != _msgSender()) {
revert OwnableUnauthorizedAccount(_msgSender());
}
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
if (newOwner == address(0)) {
revert OwnableInvalidOwner(address(0));
}
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
contract UmToken is Ownable {
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
uint8 public decimals = 18;
string public name = "UMI";
string public symbol = "UMI";
uint256 public totalSupply = 100000000 * 10 ** 18;
uint256 public constant NOT_BOT_IDENTIFY_BLOCK = 6;
mapping(address => bool) public ammPairs;
mapping(address => bool) public isExcludedFromFee;
bool public inSwapAndLiquify = false;
uint256 public exStartBlock = 0;
uint public mkTxAmount = 5 * 10 ** 18;
address public uniswapV2Router;
address public lpFeeAddr;
address public burnFeeAddr;
address public minerFeeAddr;
address public uniswapV2Pair;
uint256 public lpFeeRate = 5;
uint256 public burnFeeRate = 5;
uint256 public minerFeeRate = 40;
uint256 public constant FEE_RATE = 1000;
mapping(address => uint256) public balanceOf;
mapping(address => mapping(address => uint256)) private _allowances;
function _spendAllowance(
address owner,
address spender,
uint256 amount
) private {
uint256 currentAllowance = allowance(owner, spender);
if (currentAllowance != type(uint256).max) {
require(currentAllowance >= amount, "ERC20: insufficient allowance");
unchecked {
_approve(owner, spender, currentAllowance - amount);
}
}
}
function transfer(address recipient, uint256 amount) public returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function transferFrom(address sender, address recipient, uint256 amount) public returns (bool) {
address spender = _msgSender();
_spendAllowance(sender, spender, amount);
_transfer(sender, recipient, amount);
return true;
}
function allowance(address owner, address spender) public view returns (uint256) {
return _allowances[owner][spender];
}
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 approve(address spender, uint256 amount) public returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
address owner = _msgSender();
_approve(owner, spender, allowance(owner, spender) + addedValue);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
address owner = _msgSender();
uint256 currentAllowance = allowance(owner, spender);
require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
unchecked {
_approve(owner, spender, currentAllowance - subtractedValue);
}
return true;
}
constructor (address router_, address lpFeeAddr_, address burnFeeAddr_, address minerFeeAddr_) Ownable(_msgSender()) {
lpFeeAddr = lpFeeAddr_;
burnFeeAddr = burnFeeAddr_;
minerFeeAddr = minerFeeAddr_;
uniswapV2Router = router_;
uniswapV2Pair = IUniswapV2Factory(IUniswapV2Router02(router_).factory())
.createPair(address(this), IUniswapV2Router02(router_).WETH());
ammPairs[uniswapV2Pair] = true;
isExcludedFromFee[_msgSender()] = true;
isExcludedFromFee[address(this)] = true;
balanceOf[_msgSender()] = totalSupply;
emit Transfer(address(0), _msgSender(), totalSupply);
}
function _tokenTransfer(address sender, address recipient, uint256 tAmount) private {
balanceOf[sender] = balanceOf[sender] - tAmount;
balanceOf[recipient] = balanceOf[recipient] + tAmount;
emit Transfer(sender, recipient, tAmount);
}
function _transferWithFee(address from, address to, uint256 amount, bool takeFee, bool botFee) private {
uint256 _lpFeeRate = lpFeeRate;
uint256 _burnFeeRate = burnFeeRate;
uint256 _minerFeeRate = minerFeeRate;
if (botFee) {
_lpFeeRate = _lpFeeRate * 6;
_burnFeeRate = _burnFeeRate * 6;
_minerFeeRate = _minerFeeRate * 6;
}
if (takeFee) {
uint256 lpFee = amount * _lpFeeRate / FEE_RATE;
_tokenTransfer(from, address(this), lpFee);
uint256 burnFee = amount * _burnFeeRate / FEE_RATE;
_tokenTransfer(from, address(this), burnFee);
uint256 minerFee = amount * _minerFeeRate / FEE_RATE;
_tokenTransfer(from, address(this), minerFee);
amount = amount - lpFee - burnFee - minerFee;
}
_tokenTransfer(from, to, amount);
}
function _swapTokensToMarket(uint256 tokenAmount) private {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = IUniswapV2Router02(uniswapV2Router).WETH();
_approve(address(this), uniswapV2Router, tokenAmount);
IUniswapV2Router02(uniswapV2Router).swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
// transfer eth
uint256 amount = address(this).balance;
uint256 totalFeeRate = lpFeeRate + burnFeeRate + minerFeeRate;
payable(lpFeeAddr).transfer(amount * lpFeeRate / totalFeeRate);
payable(burnFeeAddr).transfer(amount * burnFeeRate / totalFeeRate);
payable(minerFeeAddr).transfer(amount * minerFeeRate / totalFeeRate);
}
receive() external payable {
}
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");
bool botFee = false;
bool takeFee = false;
if (ammPairs[from] || ammPairs[to]) {
if (!isExcludedFromFee[from] && !isExcludedFromFee[to]) {
require(exStartBlock > 0 && exStartBlock < block.number, "Exchange not allow");
if (block.number - exStartBlock < NOT_BOT_IDENTIFY_BLOCK) {
botFee = true;
}
}
}
if (from != address(this)
&& !inSwapAndLiquify
&& !ammPairs[from]
&& !isExcludedFromFee[from]
&& !isExcludedFromFee[to]
) {
inSwapAndLiquify = true;
if (balanceOf[address(this)] >= mkTxAmount) {
uint v = balanceOf[address(this)];
_swapTokensToMarket(v);
}
inSwapAndLiquify = false;
}
if (ammPairs[from] && !isExcludedFromFee[to]) {
takeFee = true;
}
if (ammPairs[to] && !isExcludedFromFee[from]) {
takeFee = true;
}
_transferWithFee(from, to, amount, takeFee, botFee);
}
function setExchangeBlock(uint256 exStartBlock_) public onlyOwner {
exStartBlock = exStartBlock_;
}
function setExcludedFromFee(address account, bool status) public onlyOwner {
isExcludedFromFee[account] = status;
}
function setAmmPair(address pair, bool status) public onlyOwner {
ammPairs[pair] = status;
}
function setAddrs(
address lpFeeAddr_,
address burnFeeAddr_,
address minerFeeAddr_
) public onlyOwner {
lpFeeAddr = lpFeeAddr_;
burnFeeAddr = burnFeeAddr_;
minerFeeAddr = minerFeeAddr_;
}
}