Created
January 2, 2024 12:51
-
-
Save jadeden1999/3ff71390d562f54dc5ae8309e5d4d0e0 to your computer and use it in GitHub Desktop.
Created using remix-ide: Realtime Ethereum Contract Compiler and Runtime. Load this file by pasting this gists URL or ID at https://remix.ethereum.org/#version=soljson-v0.8.18+commit.87f61d96.js&optimize=true&runs=200&gist=
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
*Submitted for verification at Etherscan.io on 2023-05-15 | |
*/ | |
// SPDX-License-Identifier: MIT | |
// Website https://pearswap.net/ | |
// Telegram Telegram https://t.me/pearswaptg | |
// Twitter https://twitter.com/Pearswapnet | |
// Medium https://medium.com/@pearswap | |
pragma solidity ^0.8.11; | |
interface IERC20 { | |
function totalSupply() external view returns (uint256); | |
function balanceOf(address account) external view returns (uint256); | |
function transfer(address to, 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 from, | |
address to, | |
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 IERC20Metadata is IERC20 { | |
function name() external view returns (string memory); | |
function symbol() external view returns (string memory); | |
function decimals() external view returns (uint8); | |
} | |
abstract contract Context { | |
function _msgSender() internal view virtual returns (address) { | |
return msg.sender; | |
} | |
function _msgData() internal view virtual returns (bytes calldata) { | |
return msg.data; | |
} | |
} | |
contract ERC20 is Context, IERC20, IERC20Metadata { | |
mapping(address => uint256) private _balances; | |
mapping(address => mapping(address => uint256)) private _allowances; | |
uint256 private _totalSupply; | |
string private _name; | |
string private _symbol; | |
constructor(string memory name_, string memory symbol_) { | |
_name = name_; | |
_symbol = symbol_; | |
} | |
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 to, uint256 amount) | |
public | |
virtual | |
override | |
returns (bool) | |
{ | |
address owner = _msgSender(); | |
_transfer(owner, to, 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) | |
{ | |
address owner = _msgSender(); | |
_approve(owner, spender, amount); | |
return true; | |
} | |
function transferFrom( | |
address from, | |
address to, | |
uint256 amount | |
) public virtual override returns (bool) { | |
address spender = _msgSender(); | |
_spendAllowance(from, spender, amount); | |
_transfer(from, to, amount); | |
return true; | |
} | |
function _transfer( | |
address from, | |
address to, | |
uint256 amount | |
) internal virtual { | |
require(from != address(0), "ERC20: a from the zero address"); | |
require(to != address(0), "ERC20: transfer to the zero address"); | |
_beforeTokenTransfer(from, to, amount); | |
uint256 fromBalance = _balances[from]; | |
require( | |
fromBalance >= amount, | |
"ERC20: transfer amount exceeds balance" | |
); | |
unchecked { | |
_balances[from] = fromBalance - amount; | |
_balances[to] += amount; | |
} | |
emit Transfer(from, to, amount); | |
_afterTokenTransfer(from, to, 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; | |
emit Transfer(address(0), account, amount); | |
_afterTokenTransfer(address(0), account, 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 _spendAllowance( | |
address owner, | |
address spender, | |
uint256 amount | |
) internal virtual { | |
uint256 currentAllowance = allowance(owner, spender); | |
if (currentAllowance != type(uint256).max) { | |
require( | |
currentAllowance >= amount, | |
"ERC20: insufficient allowance" | |
); | |
unchecked { | |
_approve(owner, spender, currentAllowance - 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 IUniswapV2Pair { | |
event Approval( | |
address indexed owner, | |
address indexed spender, | |
uint256 value | |
); | |
event Transfer(address indexed from, address indexed to, uint256 value); | |
function name() external pure returns (string memory); | |
function symbol() external pure returns (string memory); | |
function decimals() external pure returns (uint8); | |
function totalSupply() external view returns (uint256); | |
function balanceOf(address owner) external view returns (uint256); | |
function allowance(address owner, address spender) | |
external | |
view | |
returns (uint256); | |
function approve(address spender, uint256 value) external returns (bool); | |
function transfer(address to, uint256 value) external returns (bool); | |
function transferFrom( | |
address from, | |
address to, | |
uint256 value | |
) external returns (bool); | |
function DOMAIN_SEPARATOR() external view returns (bytes32); | |
function PERMIT_TYPEHASH() external pure returns (bytes32); | |
function nonces(address owner) external view returns (uint256); | |
function permit( | |
address owner, | |
address spender, | |
uint256 value, | |
uint256 deadline, | |
uint8 v, | |
bytes32 r, | |
bytes32 s | |
) external; | |
event Mint(address indexed sender, uint256 amount0, uint256 amount1); | |
event Swap( | |
address indexed sender, | |
uint256 amount0In, | |
uint256 amount1In, | |
uint256 amount0Out, | |
uint256 amount1Out, | |
address indexed to | |
); | |
event Sync(uint112 reserve0, uint112 reserve1); | |
function MINIMUM_LIQUIDITY() external pure returns (uint256); | |
function factory() external view returns (address); | |
function token0() external view returns (address); | |
function token1() external view returns (address); | |
function getReserves() | |
external | |
view | |
returns ( | |
uint112 reserve0, | |
uint112 reserve1, | |
uint32 blockTimestampLast | |
); | |
function price0CumulativeLast() external view returns (uint256); | |
function price1CumulativeLast() external view returns (uint256); | |
function kLast() external view returns (uint256); | |
function mint(address to) external returns (uint256 liquidity); | |
function swap( | |
uint256 amount0Out, | |
uint256 amount1Out, | |
address to, | |
bytes calldata data | |
) external; | |
function skim(address to) external; | |
function sync() external; | |
function initialize(address, address) external; | |
} | |
interface IUniswapV2Router01 { | |
function factory() external pure returns (address); | |
function WETH() external pure returns (address); | |
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 | |
); | |
function addLiquidityETH( | |
address token, | |
uint256 amountTokenDesired, | |
uint256 amountTokenMin, | |
uint256 amountETHMin, | |
address to, | |
uint256 deadline | |
) | |
external | |
payable | |
returns ( | |
uint256 amountToken, | |
uint256 amountETH, | |
uint256 liquidity | |
); | |
function removeLiquidity( | |
address tokenA, | |
address tokenB, | |
uint256 liquidity, | |
uint256 amountAMin, | |
uint256 amountBMin, | |
address to, | |
uint256 deadline | |
) external returns (uint256 amountA, uint256 amountB); | |
function removeLiquidityETH( | |
address token, | |
uint256 liquidity, | |
uint256 amountTokenMin, | |
uint256 amountETHMin, | |
address to, | |
uint256 deadline | |
) external returns (uint256 amountToken, uint256 amountETH); | |
function removeLiquidityWithPermit( | |
address tokenA, | |
address tokenB, | |
uint256 liquidity, | |
uint256 amountAMin, | |
uint256 amountBMin, | |
address to, | |
uint256 deadline, | |
bool approveMax, | |
uint8 v, | |
bytes32 r, | |
bytes32 s | |
) external returns (uint256 amountA, uint256 amountB); | |
function removeLiquidityETHWithPermit( | |
address token, | |
uint256 liquidity, | |
uint256 amountTokenMin, | |
uint256 amountETHMin, | |
address to, | |
uint256 deadline, | |
bool approveMax, | |
uint8 v, | |
bytes32 r, | |
bytes32 s | |
) external returns (uint256 amountToken, uint256 amountETH); | |
function swapExactTokensForTokens( | |
uint256 amountIn, | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external returns (uint256[] memory amounts); | |
function swapTokensForExactTokens( | |
uint256 amountOut, | |
uint256 amountInMax, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external returns (uint256[] memory amounts); | |
function swapExactETHForTokens( | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external payable returns (uint256[] memory amounts); | |
function swapTokensForExactETH( | |
uint256 amountOut, | |
uint256 amountInMax, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external returns (uint256[] memory amounts); | |
function swapExactTokensForETH( | |
uint256 amountIn, | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external returns (uint256[] memory amounts); | |
function swapETHForExactTokens( | |
uint256 amountOut, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external payable returns (uint256[] memory amounts); | |
function quote( | |
uint256 amountA, | |
uint256 reserveA, | |
uint256 reserveB | |
) external pure returns (uint256 amountB); | |
function getAmountOut( | |
uint256 amountIn, | |
uint256 reserveIn, | |
uint256 reserveOut | |
) external pure returns (uint256 amountOut); | |
function getAmountIn( | |
uint256 amountOut, | |
uint256 reserveIn, | |
uint256 reserveOut | |
) external pure returns (uint256 amountIn); | |
function getAmountsOut(uint256 amountIn, address[] calldata path) | |
external | |
view | |
returns (uint256[] memory amounts); | |
function getAmountsIn(uint256 amountOut, address[] calldata path) | |
external | |
view | |
returns (uint256[] memory amounts); | |
} | |
interface IUniswapV2Router02 is IUniswapV2Router01 { | |
function removeLiquidityETHSupportingFeeOnTransferTokens( | |
address token, | |
uint256 liquidity, | |
uint256 amountTokenMin, | |
uint256 amountETHMin, | |
address to, | |
uint256 deadline | |
) external returns (uint256 amountETH); | |
function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( | |
address token, | |
uint256 liquidity, | |
uint256 amountTokenMin, | |
uint256 amountETHMin, | |
address to, | |
uint256 deadline, | |
bool approveMax, | |
uint8 v, | |
bytes32 r, | |
bytes32 s | |
) external returns (uint256 amountETH); | |
function swapExactTokensForTokensSupportingFeeOnTransferTokens( | |
uint256 amountIn, | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external; | |
function swapExactETHForTokensSupportingFeeOnTransferTokens( | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external payable; | |
function swapExactTokensForETHSupportingFeeOnTransferTokens( | |
uint256 amountIn, | |
uint256 amountOutMin, | |
address[] calldata path, | |
address to, | |
uint256 deadline | |
) external; | |
} | |
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); | |
} | |
} | |
contract PEAR is ERC20, Ownable { | |
IUniswapV2Router02 private uniswapV2Router; | |
address private uniswapV2Pair; | |
bool private _swapping; | |
address public MarketingWallet; | |
uint256 private swapAt = 25000 * (10 ** decimals()); | |
uint256 public maxTransactionAmountOnPurchase; | |
uint256 public maxTransactionAmountOnSale; | |
uint256 public maxWallet; | |
bool public feesDisabled = false; | |
bool public tradingLive = false; | |
uint256 private _fundingFee = 1; | |
uint256 private _tokensForFunding; | |
uint256 public buyFee; | |
uint256 public sellFee; | |
bool public buyStatus; | |
bool public sellStatus; | |
uint256 public totalFees = _fundingFee; | |
mapping(address => bool) private _isExcludedFromFees; | |
mapping(address => bool) private _isExcludedMaxTransactionAmount; | |
mapping(address => bool) private _automatedMarketMakerPairs; | |
constructor(string memory name, string memory symbol,uint256 _buyFee,uint256 _sellFee,uint256 _swapTreshold) payable ERC20(name,symbol) { | |
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02( | |
0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D ); | |
_isExcludedMaxTransactionAmount[address(_uniswapV2Router)] = true; | |
uniswapV2Router = _uniswapV2Router; | |
buyFee = _buyFee; | |
sellFee = _sellFee; | |
addSwapTreshold(_swapTreshold); | |
uint256 totalSupply = 100000000 * 1e18; | |
sellStatus = true; | |
buyStatus = true; | |
MarketingWallet = msg.sender; | |
updateLimits(1000001,1000001,1000001); | |
excludeFromFees(owner(), true); | |
excludeFromFees(address(this), true); | |
excludeFromFees(address(0xdead), true); | |
excludeFromFees(MarketingWallet, true); | |
_isExcludedMaxTransactionAmount[owner()] = true; | |
_isExcludedMaxTransactionAmount[address(this)] = true; | |
_isExcludedMaxTransactionAmount[MarketingWallet] = true; | |
_mint(owner(), totalSupply); | |
} | |
function removeTxLimits() public onlyOwner{ | |
maxTransactionAmountOnPurchase = 2**256 - 1; | |
maxTransactionAmountOnSale = 2**256 - 1; | |
maxWallet = 2**256 - 1; | |
} | |
function setUniswapPair(address _pair) public onlyOwner{ | |
uniswapV2Pair = _pair; | |
_automatedMarketMakerPairs[_pair] = true; | |
_isExcludedMaxTransactionAmount[_pair] = true; | |
} | |
function addSwapTreshold(uint256 _percent) public onlyOwner { | |
swapAt = (totalSupply() * _percent) / 100000000; | |
} | |
function setTaxWallets(address fundingWallet) public onlyOwner{ | |
MarketingWallet = fundingWallet; | |
} | |
function enableTrading() external onlyOwner { | |
tradingLive = true; | |
} | |
function excludeFromFees(address account, bool excluded) | |
public // changed from public to private | |
onlyOwner | |
{ | |
_isExcludedFromFees[account] = excluded; | |
} | |
function updateTradingFees(uint256 _buyFee,uint256 _sellFee) public onlyOwner { | |
require(_buyFee <= 99 && _sellFee <= 99, "Too much fee"); | |
buyFee = _buyFee; | |
sellFee = _sellFee; | |
} | |
function updateLimits( | |
uint256 buyLimit, | |
uint256 sellLimit, | |
uint256 _maxWallet | |
) public onlyOwner { | |
maxTransactionAmountOnPurchase = buyLimit * (10**decimals()); | |
maxTransactionAmountOnSale = sellLimit * (10**decimals()); | |
maxWallet = _maxWallet * (10**decimals()); | |
} | |
function isExcludedFromFees(address account) external view returns (bool) { | |
return _isExcludedFromFees[account]; | |
} | |
function _transfer( | |
address from, | |
address to, | |
uint256 amount | |
) internal override { | |
require(from != address(0), "ERC20: transfer from the zero address"); | |
require(to != address(0), "ERC20: transfer to the zero address"); | |
if (amount == 0) { | |
super._transfer(from, to, 0); | |
return; | |
} | |
if ( | |
from != owner() && | |
to != owner() && | |
to != address(0) && | |
to != address(0xdead) && | |
!_swapping | |
) { | |
if (!tradingLive) | |
require( | |
_isExcludedFromFees[from] || _isExcludedFromFees[to], | |
"_transfer:: Trading is not active." | |
); | |
// on buy | |
if ( | |
_automatedMarketMakerPairs[from] && | |
!_isExcludedMaxTransactionAmount[to] | |
) { | |
require( | |
amount <= maxTransactionAmountOnPurchase, | |
"_transfer:: Buy transfer amount exceeds the maxTransactionAmount." | |
); | |
require( | |
amount + balanceOf(to) <= maxWallet, | |
"_transfer:: Max wallet exceeded" | |
); | |
} | |
// on sell | |
else if ( | |
_automatedMarketMakerPairs[to] && | |
!_isExcludedMaxTransactionAmount[from] | |
) { | |
require( | |
amount <= maxTransactionAmountOnSale, | |
"_transfer:: Sell transfer amount exceeds the maxTransactionAmount." | |
); | |
} else if (!_isExcludedMaxTransactionAmount[to]) { | |
require( | |
amount + balanceOf(to) <= maxWallet, | |
"_transfer:: Max wallet exceeded" | |
); | |
} | |
} | |
bool CanISwap = balanceOf(address(this)) >= swapAt; | |
if ( | |
CanISwap && | |
!_swapping && | |
!_automatedMarketMakerPairs[from] && | |
!_isExcludedFromFees[from] && | |
!_isExcludedFromFees[to] | |
) { | |
_swapping = true; | |
swapBack(); | |
_swapping = false; | |
} | |
bool takeFee = !_swapping; | |
if ( | |
feesDisabled || | |
_isExcludedFromFees[from] || | |
_isExcludedFromFees[to] || | |
(!_automatedMarketMakerPairs[from] && | |
!_automatedMarketMakerPairs[to]) | |
) takeFee = false; | |
uint256 fees = 0; | |
if (takeFee) { | |
uint256 feePercent; | |
if(to == uniswapV2Pair){ | |
require(sellStatus,"Sell status is closed"); | |
feePercent = sellFee; | |
}else if(from == uniswapV2Pair){ | |
require(buyStatus,"Buy status is closed"); | |
feePercent = buyFee; | |
} | |
fees = amount * feePercent / 100; | |
_tokensForFunding += (fees * _fundingFee) / totalFees; | |
if (fees > 0) { | |
super._transfer(from, address(this), fees); | |
} | |
amount -= fees; | |
} | |
super._transfer(from, to, amount); | |
} | |
function _swapTokensForETH(uint256 tokenAmount) internal { | |
if(tokenAmount != 0){ | |
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 _addLiquidity(uint256 tokenAmount, uint256 ethAmount) internal { | |
_approve(address(this), address(uniswapV2Router), tokenAmount); | |
uniswapV2Router.addLiquidityETH{value: ethAmount}( | |
address(this), | |
tokenAmount, | |
0, | |
0, | |
owner(), | |
block.timestamp | |
); | |
} | |
function swapBack() public { | |
uint256 contractBalance = balanceOf(address(this)); | |
if (contractBalance == 0) return; | |
_swapTokensForETH(_tokensForFunding); | |
payable(MarketingWallet).transfer(address(this).balance); | |
_tokensForFunding = 0; | |
} | |
receive() external payable {} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment