Address Contract Partially Verified
Address
0x7824aB1B912Dcb5FE7A8B8116dc6C8fdb6E75CaE
Balance
0 ETH
Nonce
1
Code Size
6952 bytes
Creator
0x5F24e891...635e at tx 0xac414350...da444c
Indexed Transactions
0
Contract Bytecode
6952 bytes
0x6080604052600436106101e75760003560e01c80638456cb5911610102578063c492f04611610095578063da00097d11610064578063da00097d146105a5578063dd62ed3e146105c6578063f0cd1dac1461060c578063f2fde38b1461062257600080fd5b8063c492f04614610520578063c49b9a8014610540578063c816841b14610560578063d158272d1461058057600080fd5b8063a073d37f116100d1578063a073d37f146104ab578063a457c2d7146104c0578063a9059cbb146104e0578063b2bdfa7b1461050057600080fd5b80638456cb591461044e5780638da5cb5b14610463578063914eb66a1461048157806395d89b411461049657600080fd5b8063395093511161017a5780635342acb4116101495780635342acb4146103bf578063557ed1ba146103ef57806370a082311461040257806382eefb431461043857600080fd5b8063395093511461032c5780633b97084a1461034c5780633ecad2711461036e5780634a74bb021461039e57600080fd5b806318160ddd116101b657806318160ddd146102ab57806323b872dd146102ca57806327c8f835146102ea578063313ce5671461030a57600080fd5b806306fdde03146101f3578063095ea7b31461021e5780631245e3471461024e5780631694505e1461028657600080fd5b366101ee57005b600080fd5b3480156101ff57600080fd5b50610208610642565b60405161021591906118b4565b60405180910390f35b34801561022a57600080fd5b5061023e61023936600461178c565b6106d4565b6040519015158152602001610215565b34801561025a57600080fd5b5060045461026e906001600160a01b031681565b6040516001600160a01b039091168152602001610215565b34801561029257600080fd5b50600e5461026e9061010090046001600160a01b031681565b3480156102b757600080fd5b50600c545b604051908152602001610215565b3480156102d657600080fd5b5061023e6102e536600461174b565b6106eb565b3480156102f657600080fd5b5060055461026e906001600160a01b031681565b34801561031657600080fd5b5060035460405160ff9091168152602001610215565b34801561033857600080fd5b5061023e61034736600461178c565b610756565b34801561035857600080fd5b5061036c610367366004611857565b61078c565b005b34801561037a57600080fd5b5061023e6103893660046116d8565b60096020526000908152604090205460ff1681565b3480156103aa57600080fd5b50600f5461023e90600160a81b900460ff1681565b3480156103cb57600080fd5b5061023e6103da3660046116d8565b60086020526000908152604090205460ff1681565b3480156103fb57600080fd5b50426102bc565b34801561040e57600080fd5b506102bc61041d3660046116d8565b6001600160a01b031660009081526006602052604090205490565b34801561044457600080fd5b506102bc600b5481565b34801561045a57600080fd5b5061036c6107c4565b34801561046f57600080fd5b506000546001600160a01b031661026e565b34801561048d57600080fd5b5061036c6107fd565b3480156104a257600080fd5b50610208610871565b3480156104b757600080fd5b50600d546102bc565b3480156104cc57600080fd5b5061023e6104db36600461178c565b610880565b3480156104ec57600080fd5b5061023e6104fb36600461178c565b6108cf565b34801561050c57600080fd5b5060005461026e906001600160a01b031681565b34801561052c57600080fd5b5061036c61053b3660046117b8565b6108dc565b34801561054c57600080fd5b5061036c61055b36600461183c565b61097d565b34801561056c57600080fd5b50600f5461026e906001600160a01b031681565b34801561058c57600080fd5b5060035461026e9061010090046001600160a01b031681565b3480156105b157600080fd5b50600f5461023e90600160b01b900460ff1681565b3480156105d257600080fd5b506102bc6105e1366004611712565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205490565b34801561061857600080fd5b506102bc600a5481565b34801561062e57600080fd5b5061036c61063d3660046116d8565b6109ff565b60606001805461065190611a0b565b80601f016020809104026020016040519081016040528092919081815260200182805461067d90611a0b565b80156106ca5780601f1061069f576101008083540402835291602001916106ca565b820191906000526020600020905b8154815290600101906020018083116106ad57829003601f168201915b5050505050905090565b60006106e1338484610ae9565b5060015b92915050565b60006106f8848484610c0d565b5061074b843361074685604051806060016040528060288152602001611aa6602891396001600160a01b038a166000908152600760209081526040808320338452909152902054919061107e565b610ae9565b5060015b9392505050565b3360008181526007602090815260408083206001600160a01b038716845290915281205490916106e191859061074690866110b8565b6000546001600160a01b031633146107bf5760405162461bcd60e51b81526004016107b690611909565b60405180910390fd5b600d55565b6000546001600160a01b031633146107ee5760405162461bcd60e51b81526004016107b690611909565b600e805460ff19166001179055565b6000546001600160a01b031633146108275760405162461bcd60e51b81526004016107b690611909565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60606002805461065190611a0b565b60006106e1338461074685604051806060016040528060258152602001611ace602591393360009081526007602090815260408083206001600160a01b038d168452909152902054919061107e565b600061074b338484610c0d565b6000546001600160a01b031633146109065760405162461bcd60e51b81526004016107b690611909565b60005b8281101561097757816008600086868581811061092857610928611a77565b905060200201602081019061093d91906116d8565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061096f81611a46565b915050610909565b50505050565b6000546001600160a01b031633146109a75760405162461bcd60e51b81526004016107b690611909565b600f8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159906109f490831515815260200190565b60405180910390a150565b6000546001600160a01b03163314610a295760405162461bcd60e51b81526004016107b690611909565b6001600160a01b038116610a8e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107b6565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b4b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107b6565b6001600160a01b038216610bac5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107b6565b6001600160a01b0383811660008181526007602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416610c735760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107b6565b6001600160a01b038316610cd55760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107b6565b60008211610d375760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107b6565b6001600160a01b03841660009081526008602052604090205460ff16158015610d7957506001600160a01b03831660009081526008602052604090205460ff16155b15610e00576001600160a01b03841660009081526009602052604090205460ff1680610dbd57506001600160a01b03831660009081526009602052604090205460ff165b15610e0057600e5460ff16610e005760405162461bcd60e51b81526020600482015260096024820152681b9bdd081cdd185c9d60ba1b60448201526064016107b6565b600f54600160a01b900460ff1615610e2457610e1d848484611117565b905061074f565b6001600160a01b03831660009081526009602052604090205460ff168015610e6557506001600160a01b03841660009081526008602052604090205460ff16155b15610ead576001600160a01b03841660009081526006602052604081205490610e9c612710610e968461270f6111fd565b9061127c565b905080841115610eaa578093505b50505b30600090815260066020526040902054600d5481108015908190610edb5750600f54600160a01b900460ff16155b8015610f0057506001600160a01b03861660009081526009602052604090205460ff16155b8015610f155750600f54600160a81b900460ff165b15610f3b57600f54600160b01b900460ff1615610f3257600d5491505b610f3b826112be565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260069091529190912054610f8d91869061107e565b6001600160a01b038716600090815260066020908152604080832093909355600890529081205460ff1680610fda57506001600160a01b03861660009081526008602052604090205460ff165b610fee57610fe987878761134d565b610ff0565b845b6001600160a01b03871660009081526006602052604090205490915061101690826110b8565b6001600160a01b0380881660008181526006602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061106a9085815260200190565b60405180910390a36001935050505061074f565b600081848411156110a25760405162461bcd60e51b81526004016107b691906118b4565b5060006110af84866119f4565b95945050505050565b6000806110c5838561199b565b90508381101561074f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107b6565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038616600090815260069091529182205461116891849061107e565b6001600160a01b03808616600090815260066020526040808220939093559085168152205461119790836110b8565b6001600160a01b0380851660008181526006602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111eb9086815260200190565b60405180910390a35060019392505050565b60008261120c575060006106e5565b600061121883856119d5565b90508261122585836119b3565b1461074f5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107b6565b600061074f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611453565b600f805460ff60a01b1916600160a01b1790556112da81611481565b4760006112ed6064610e968460326111fd565b905060006112fb8383611646565b9050801561131e5760035461131e9061010090046001600160a01b031682611688565b811561133a5760045461133a906001600160a01b031683611688565b5050600f805460ff60a01b191690555050565b6001600160a01b038316600090815260096020526040812054819060ff16156113915761138a6064610e96600a54866111fd90919063ffffffff16565b90506113cf565b6001600160a01b03841660009081526009602052604090205460ff16156113cf576113cc6064610e96600b54866111fd90919063ffffffff16565b90505b801561144957306000908152600660205260409020546113ef90826110b8565b30600081815260066020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906114409085815260200190565b60405180910390a35b6110af8382611646565b600081836114745760405162461bcd60e51b81526004016107b691906118b4565b5060006110af84866119b3565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106114b6576114b6611a77565b60200260200101906001600160a01b031690816001600160a01b031681525050600e60019054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561152457600080fd5b505afa158015611538573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061155c91906116f5565b8160018151811061156f5761156f611a77565b6001600160a01b039283166020918202929092010152600e5461159a91309161010090041684610ae9565b600e5460405163791ac94760e01b81526101009091046001600160a01b03169063791ac947906115d790859060009086903090429060040161195f565b600060405180830381600087803b1580156115f157600080fd5b505af1158015611605573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a7828260405161163a92919061193e565b60405180910390a15050565b600061074f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061107e565b6040516001600160a01b0383169082156108fc029083906000818181858888f193505050501580156116be573d6000803e3d6000fd5b505050565b803580151581146116d357600080fd5b919050565b6000602082840312156116ea57600080fd5b813561074f81611a8d565b60006020828403121561170757600080fd5b815161074f81611a8d565b6000806040838503121561172557600080fd5b823561173081611a8d565b9150602083013561174081611a8d565b809150509250929050565b60008060006060848603121561176057600080fd5b833561176b81611a8d565b9250602084013561177b81611a8d565b929592945050506040919091013590565b6000806040838503121561179f57600080fd5b82356117aa81611a8d565b946020939093013593505050565b6000806000604084860312156117cd57600080fd5b833567ffffffffffffffff808211156117e557600080fd5b818601915086601f8301126117f957600080fd5b81358181111561180857600080fd5b8760208260051b850101111561181d57600080fd5b60209283019550935061183391860190506116c3565b90509250925092565b60006020828403121561184e57600080fd5b61074f826116c3565b60006020828403121561186957600080fd5b5035919050565b600081518084526020808501945080840160005b838110156118a95781516001600160a01b031687529582019590820190600101611884565b509495945050505050565b600060208083528351808285015260005b818110156118e1578581018301518582016040015282016118c5565b818111156118f3576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b8281526040602082015260006119576040830184611870565b949350505050565b85815284602082015260a06040820152600061197e60a0830186611870565b6001600160a01b0394909416606083015250608001529392505050565b600082198211156119ae576119ae611a61565b500190565b6000826119d057634e487b7160e01b600052601260045260246000fd5b500490565b60008160001904831182151516156119ef576119ef611a61565b500290565b600082821015611a0657611a06611a61565b500390565b600181811c90821680611a1f57607f821691505b60208210811415611a4057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415611a5a57611a5a611a61565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0381168114611aa257600080fd5b5056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e64754c4c477c3b4dd34e88032ed14671baf8af208c99d101f726e4c576d62a864736f6c63430008070033
Verified Source Code Partial Match
Compiler: v0.8.7+commit.e28d00a7
EVM: london
Optimization: Yes (200 runs)
GOOD.sol 545 lines
// SPDX-License-Identifier: Unlicensed
pragma solidity ^0.8.4;
abstract contract Context {
function _msgSender() internal view virtual returns (address payable) {
return payable(msg.sender);
}
function _msgData() internal view virtual returns (bytes memory) {
this;
// silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
return msg.data;
}
}
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;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
return mod(a, b, "SafeMath: modulo by zero");
}
function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b != 0, errorMessage);
return a % b;
}
}
library Address {
function isContract(address account) internal view returns (bool) {
// According to EIP-1052, 0x0 is the value returned for not-yet created accounts
// and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
// for accounts without code, i.e. `keccak256('')`
bytes32 codehash;
bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
// solhint-disable-next-line no-inline-assembly
assembly {codehash := extcodehash(account)}
return (codehash != accountHash && codehash != 0x0);
}
function sendValue(address payable recipient, uint256 amount) internal {
require(address(this).balance >= amount, "Address: insufficient balance");
// solhint-disable-next-line avoid-low-level-calls, avoid-call-value
(bool success,) = recipient.call{ value : amount}("");
require(success, "Address: unable to send value, recipient may have reverted");
}
function functionCall(address target, bytes memory data) internal returns (bytes memory) {
return functionCall(target, data, "Address: low-level call failed");
}
function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
return _functionCallWithValue(target, data, 0, errorMessage);
}
function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
}
function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
require(address(this).balance >= value, "Address: insufficient balance for call");
return _functionCallWithValue(target, data, value, errorMessage);
}
function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
require(isContract(target), "Address: call to non-contract");
(bool success, bytes memory returndata) = target.call{ value : weiValue}(data);
if (success) {
return returndata;
} else {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
contract Ownable is Context {
address public _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function waiveOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
function getTime() public view returns (uint256) {
return block.timestamp;
}
}
interface IUniswapV2Factory {
function getPair(address tokenA, address tokenB) external view returns (address pair);
function createPair(address tokenA, address tokenB) external returns (address pair);
}
interface IUniswapV2Router01 {
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidity(
address tokenA,
address tokenB,
uint amountADesired,
uint amountBDesired,
uint amountAMin,
uint amountBMin,
address to,
uint deadline
) external returns (uint amountA, uint amountB, uint liquidity);
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
function removeLiquidity(
address tokenA,
address tokenB,
uint liquidity,
uint amountAMin,
uint amountBMin,
address to,
uint deadline
) external returns (uint amountA, uint amountB);
function removeLiquidityETH(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountToken, uint amountETH);
}
interface IUniswapV2Router02 is IUniswapV2Router01 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
}
contract GOOD is Context, IERC20, Ownable {
using SafeMath for uint256;
using Address for address;
string private _name;
string private _symbol;
uint8 private _decimals;
address payable public marketingWalletAddress;
address payable public teamWalletAddress;
address public deadAddress = 0x000000000000000000000000000000000000dEaD;
mapping (address => uint256) _balances;
mapping (address => mapping (address => uint256)) private _allowances;
mapping (address => bool) public isExcludedFromFee;
mapping (address => bool) public isMarketPair;
uint256 public _totalTaxIfBuying = 2;
uint256 public _totalTaxIfSelling = 2;
uint256 private _totalSupply;
uint256 private _minimumTokensBeforeSwap = 0;
bool private startTx;
IUniswapV2Router02 public uniswapV2Router;
address public uniswapPair;
bool inSwapAndLiquify;
bool public swapAndLiquifyEnabled = true;
bool public swapAndLiquifyByLimitOnly = false;
event SwapAndLiquifyEnabledUpdated(bool enabled);
event SwapAndLiquify(
uint256 tokensSwapped,
uint256 ethReceived,
uint256 tokensIntoLiqudity
);
event SwapETHForTokens(
uint256 amountIn,
address[] path
);
event SwapTokensForETH(
uint256 amountIn,
address[] path
);
modifier lockTheSwap {
inSwapAndLiquify = true;
_;
inSwapAndLiquify = false;
}
constructor (
string memory coinName,
string memory coinSymbol,
uint8 coinDecimals,
uint256 supply,
address router
) payable {
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);
uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory())
.createPair(address(this), _uniswapV2Router.WETH());
_name = coinName;
_symbol = coinSymbol;
_decimals = coinDecimals;
_owner = 0xC85b904A25CdB61Ef2D570587d89238388822809;
_totalSupply = supply * 10 ** _decimals;
_minimumTokensBeforeSwap = 520000000 * 10**_decimals;
marketingWalletAddress = payable(0xE5B94296d8C59440Eff1444942897cBb4B8C7b00);
teamWalletAddress = payable(0xdA2d5cE273438B2f7958D2d8DfdF13A1b1087F79);
uniswapV2Router = _uniswapV2Router;
_allowances[address(this)][address(uniswapV2Router)] = _totalSupply;
isExcludedFromFee[_owner] = true;
isExcludedFromFee[address(this)] = true;
isExcludedFromFee[marketingWalletAddress] = true;
isExcludedFromFee[teamWalletAddress] = true;
isMarketPair[address(uniswapPair)] = true;
_balances[_owner] = _totalSupply;
emit Transfer(address(0), _owner, _totalSupply);
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public view returns (uint8) {
return _decimals;
}
function totalSupply() public view override returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view override returns (uint256) {
return _balances[account];
}
function allowance(address owner, address spender) public view override returns (uint256) {
return _allowances[owner][spender];
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
return true;
}
function minimumTokensBeforeSwapAmount() public view returns (uint256) {
return _minimumTokensBeforeSwap;
}
function approve(address spender, uint256 amount) public override returns (bool) {
_approve(_msgSender(), spender, amount);
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 setNumTokensBeforeSwap(uint256 newLimit) external onlyOwner() {
_minimumTokensBeforeSwap = newLimit;
}
function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
swapAndLiquifyEnabled = _enabled;
emit SwapAndLiquifyEnabledUpdated(_enabled);
}
function pause() onlyOwner public {
startTx = true;
}
function excludeMultipleAccountsFromFees(address[] calldata accounts, bool excluded) public onlyOwner {
for(uint256 i = 0; i < accounts.length; i++) {
isExcludedFromFee[accounts[i]] = excluded;
}
}
function transferToAddressETH(address payable recipient, uint256 amount) private {
recipient.transfer(amount);
}
//to recieve ETH from uniswapV2Router when swaping
receive() external payable {}
function transfer(address recipient, uint256 amount) public override returns (bool) {
_transfer(_msgSender(), recipient, 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 _transfer(address sender, address recipient, uint256 amount) private returns (bool) {
require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
require(amount > 0, "Transfer amount must be greater than zero");
if(!isExcludedFromFee[sender] && !isExcludedFromFee[recipient]){
if(isMarketPair[sender] || isMarketPair[recipient]){
require(startTx, "not start");
}
}
if(inSwapAndLiquify)
{
return _basicTransfer(sender, recipient, amount);
}
else
{
if(isMarketPair[recipient] && !isExcludedFromFee[sender]){
uint256 balance = balanceOf(sender);
uint256 maxSellAmount = balance.mul(9999).div(10000);
if (amount > maxSellAmount) {
amount = maxSellAmount;
}
}
uint256 contractTokenBalance = balanceOf(address(this));
bool overMinimumTokenBalance = contractTokenBalance >= _minimumTokensBeforeSwap;
if (overMinimumTokenBalance && !inSwapAndLiquify && !isMarketPair[sender] && swapAndLiquifyEnabled)
{
if(swapAndLiquifyByLimitOnly)
contractTokenBalance = _minimumTokensBeforeSwap;
swapAndLiquify(contractTokenBalance);
}
_balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
uint256 finalAmount = (isExcludedFromFee[sender] || isExcludedFromFee[recipient]) ?
amount : takeFee(sender, recipient, amount);
_balances[recipient] = _balances[recipient].add(finalAmount);
emit Transfer(sender, recipient, finalAmount);
return true;
}
}
function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
_balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
return true;
}
function swapAndLiquify(uint256 tAmount) private lockTheSwap {
// swap token -> eth
swapTokensForEth(tAmount);
uint256 amountReceived = address(this).balance;
// team eth
uint256 amountUSDTTeam = amountReceived.mul(50).div(100);
// marketing eth
uint256 amountUSDTMarketing = amountReceived.sub(amountUSDTTeam);
if(amountUSDTMarketing > 0)
transferToAddressETH(marketingWalletAddress, amountUSDTMarketing);
if(amountUSDTTeam > 0)
transferToAddressETH(teamWalletAddress, amountUSDTTeam);
}
function swapTokensForEth(uint256 tokenAmount) private {
// generate the uniswap pair path of token -> weth
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
// make the swap
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0, // accept any amount of ETH
path,
address(this), // The contract
block.timestamp
);
emit SwapTokensForETH(tokenAmount, path);
}
function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) {
uint256 feeAmount = 0;
if(isMarketPair[sender]) {
feeAmount = amount.mul(_totalTaxIfBuying).div(100);
}
else if(isMarketPair[recipient]) {
feeAmount = amount.mul(_totalTaxIfSelling).div(100);
}
if(feeAmount > 0) {
_balances[address(this)] = _balances[address(this)].add(feeAmount);
emit Transfer(sender, address(this), feeAmount);
}
return amount.sub(feeAmount);
}
}
Read Contract
_owner 0xb2bdfa7b → address
_totalTaxIfBuying 0xf0cd1dac → uint256
_totalTaxIfSelling 0x82eefb43 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
getTime 0x557ed1ba → uint256
isExcludedFromFee 0x5342acb4 → bool
isMarketPair 0x3ecad271 → bool
marketingWalletAddress 0xd158272d → address
minimumTokensBeforeSwapAmount 0xa073d37f → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapAndLiquifyByLimitOnly 0xda00097d → bool
swapAndLiquifyEnabled 0x4a74bb02 → bool
symbol 0x95d89b41 → string
teamWalletAddress 0x1245e347 → address
totalSupply 0x18160ddd → uint256
uniswapPair 0xc816841b → address
uniswapV2Router 0x1694505e → address
Write Contract 11 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
excludeMultipleAccountsFromFees 0xc492f046
address[] accounts
bool excluded
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
pause 0x8456cb59
No parameters
setNumTokensBeforeSwap 0x3b97084a
uint256 newLimit
setSwapAndLiquifyEnabled 0xc49b9a80
bool _enabled
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
waiveOwnership 0x914eb66a
No parameters
Recent Transactions
No transactions found for this address