Source Code
More Info
Private Name Tags
ContractCreator
TokenTracker
Latest 25 from a total of 68 transactions
| Transaction Hash |
Method
|
Block
|
From
|
|
To
|
||||
|---|---|---|---|---|---|---|---|---|---|
| Approve | 22528491 | 294 days ago | IN | 0 ETH | 0.00005314 | ||||
| Approve | 22528481 | 294 days ago | IN | 0 ETH | 0.00005348 | ||||
| Approve | 22528472 | 294 days ago | IN | 0 ETH | 0.00005302 | ||||
| Approve | 22528463 | 294 days ago | IN | 0 ETH | 0.00003006 | ||||
| Approve | 22528462 | 294 days ago | IN | 0 ETH | 0.00005135 | ||||
| Approve | 18039109 | 922 days ago | IN | 0 ETH | 0.00064783 | ||||
| Approve | 18032343 | 923 days ago | IN | 0 ETH | 0.00045301 | ||||
| Approve | 18029315 | 923 days ago | IN | 0 ETH | 0.0004968 | ||||
| Approve | 18029310 | 923 days ago | IN | 0 ETH | 0.00047644 | ||||
| Approve | 18029262 | 923 days ago | IN | 0 ETH | 0.00064621 | ||||
| Approve | 18029254 | 923 days ago | IN | 0 ETH | 0.00054159 | ||||
| Approve | 18029250 | 923 days ago | IN | 0 ETH | 0.00053204 | ||||
| Approve | 18029241 | 923 days ago | IN | 0 ETH | 0.00094138 | ||||
| Approve | 18007569 | 926 days ago | IN | 0 ETH | 0.00078541 | ||||
| Approve | 17997218 | 928 days ago | IN | 0 ETH | 0.00055031 | ||||
| Approve | 17995424 | 928 days ago | IN | 0 ETH | 0.00060677 | ||||
| Approve | 17994973 | 928 days ago | IN | 0 ETH | 0.00198539 | ||||
| Approve | 17994973 | 928 days ago | IN | 0 ETH | 0.00198539 | ||||
| Approve | 17994973 | 928 days ago | IN | 0 ETH | 0.00198539 | ||||
| Approve | 17994971 | 928 days ago | IN | 0 ETH | 0.0018533 | ||||
| Approve | 17994913 | 928 days ago | IN | 0 ETH | 0.00086778 | ||||
| Renounce Ownersh... | 17994731 | 928 days ago | IN | 0 ETH | 0.00040575 | ||||
| Remove Limits In... | 17994731 | 928 days ago | IN | 0 ETH | 0.00049671 | ||||
| Approve | 17994674 | 928 days ago | IN | 0 ETH | 0.00060983 | ||||
| Approve | 17994625 | 928 days ago | IN | 0 ETH | 0.00084789 |
Latest 25 internal transactions (View All)
Advanced mode:
| Parent Transaction Hash | Method | Block |
From
|
|
To
|
||
|---|---|---|---|---|---|---|---|
| Transfer | 18039110 | 922 days ago | 0.00457112 ETH | ||||
| Transfer | 18039110 | 922 days ago | 0.00000612 ETH | ||||
| Add Liquidity ET... | 18039110 | 922 days ago | 0.00114124 ETH | ||||
| Transfer | 18039110 | 922 days ago | 0.00570624 ETH | ||||
| Transfer | 17997221 | 928 days ago | 0.00335683 ETH | ||||
| Transfer | 17997221 | 928 days ago | 0.00000142 ETH | ||||
| Add Liquidity ET... | 17997221 | 928 days ago | 0.00083885 ETH | ||||
| Transfer | 17997221 | 928 days ago | 0.00419426 ETH | ||||
| Transfer | 17995669 | 928 days ago | 0.0083128 ETH | ||||
| Transfer | 17995669 | 928 days ago | 0.00001329 ETH | ||||
| Add Liquidity ET... | 17995669 | 928 days ago | 0.00207487 ETH | ||||
| Transfer | 17995669 | 928 days ago | 0.01037438 ETH | ||||
| Transfer | 17994995 | 928 days ago | 0.0029075 ETH | ||||
| Transfer | 17994995 | 928 days ago | 0.00000091 ETH | ||||
| Add Liquidity ET... | 17994995 | 928 days ago | 0.00072664 ETH | ||||
| Transfer | 17994995 | 928 days ago | 0.00363323 ETH | ||||
| Transfer | 17994974 | 928 days ago | 0.0029075 ETH | ||||
| Transfer | 17994974 | 928 days ago | 0.00000091 ETH | ||||
| Add Liquidity ET... | 17994974 | 928 days ago | 0.00072664 ETH | ||||
| Transfer | 17994974 | 928 days ago | 0.00363323 ETH | ||||
| Transfer | 17994921 | 928 days ago | 0.00424892 ETH | ||||
| Transfer | 17994921 | 928 days ago | 0.0000023 ETH | ||||
| Add Liquidity ET... | 17994921 | 928 days ago | 0.00106165 ETH | ||||
| Transfer | 17994921 | 928 days ago | 0.00530827 ETH | ||||
| Transfer | 17994799 | 928 days ago | 0.00697922 ETH |
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions
Loading...
Loading
Contract Name:
ShiaPrinter
Compiler Version
v0.8.21+commit.d9974bed
Optimization Enabled:
Yes with 200 runs
Other Settings:
paris EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;
import {ERC20} from "openzeppelin-contracts/contracts/token/ERC20/ERC20.sol";
import {IERC20} from "openzeppelin-contracts/contracts/token/ERC20/IERC20.sol";
import {Ownable} from "openzeppelin-contracts/contracts/access/Ownable.sol";
import {IUniswapV2Factory} from "v2-core/interfaces/IUniswapV2Factory.sol";
import {IUniswapV2Router02} from "v2-periphery/interfaces/IUniswapV2Router02.sol";
import {IUniswapV2Pair} from "v2-core/interfaces/IUniswapV2Pair.sol";
import {IDividendDistributor} from "./interfaces/IDividendDistributor.sol";
contract ShiaPrinter is ERC20, Ownable {
address private WETH;
address public immutable SHIA = address(0x43D7E65B8fF49698D9550a7F315c87E67344FB59);
uint256 public constant MAX_SUPPLY = 10 * 1e9 * 1e18;
uint256 public immutable SWAP_TOKENS_AT_AMOUNT;
uint256 public immutable MAX_TRANSACTION_AMOUNT;
uint256 public immutable MAX_WALLET;
mapping(address => bool) private _isFeeExempt;
mapping(address => bool) private _isExcludedMaxTransactionAmount;
mapping(address => bool) private _isDividendExempt;
uint256 public teamFee = 20;
uint256 public printerFee = 20;
uint256 public liquidityFee = 10;
uint256 public totalFee = teamFee + printerFee + liquidityFee;
uint256 public denominator = 1000;
IUniswapV2Router02 public router;
address public pair;
address private _teamWallet;
IDividendDistributor private distributor;
bool private _limitsInEffect = true;
bool private _swapping;
constructor(address teamWallet) ERC20("ShiaPrinter", "SHIAp") {
router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
WETH = router.WETH();
pair = IUniswapV2Factory(router.factory()).createPair(WETH, address(this));
SWAP_TOKENS_AT_AMOUNT = MAX_SUPPLY * 10 / 2000;
MAX_TRANSACTION_AMOUNT = MAX_SUPPLY / 100;
MAX_WALLET = MAX_SUPPLY * 2 / 100;
_teamWallet = teamWallet;
_isFeeExempt[teamWallet] = true;
_isFeeExempt[msg.sender] = true;
_isFeeExempt[address(router)] = true;
_isFeeExempt[address(this)] = true;
_isDividendExempt[pair] = true;
_isDividendExempt[address(this)] = true;
_isExcludedMaxTransactionAmount[msg.sender] = true;
_isExcludedMaxTransactionAmount[teamWallet] = true;
_approve(address(this), address(router), type(uint256).max);
_mint(msg.sender, MAX_SUPPLY);
}
function _transfer(address from, address to, uint256 amount) internal override {
if (amount == 0) {
super._transfer(from, to, 0);
return;
}
if (_limitsInEffect) {
if (from != owner() && to != owner() && to != address(0) && !_swapping) {
//when buy
if (pair == from && !_isExcludedMaxTransactionAmount[to]) {
require(amount <= MAX_TRANSACTION_AMOUNT, "Buy transfer amount exceeds the max transaction amount.");
require(amount + balanceOf(to) <= MAX_WALLET, "Max wallet exceeded");
}
//when sell
else if (pair == to && !_isExcludedMaxTransactionAmount[from]) {
require(
amount <= MAX_TRANSACTION_AMOUNT, "Sell transfer amount exceeds the max transaction amount."
);
} else if (!_isExcludedMaxTransactionAmount[to]) {
require(amount + balanceOf(to) <= MAX_WALLET, "Max wallet exceeded");
}
}
}
uint256 contractTokenBalance = balanceOf(address(this));
bool canSwap = contractTokenBalance >= SWAP_TOKENS_AT_AMOUNT;
if (canSwap && !_swapping && from != address(pair)) {
_swapping = true;
_swapBack();
_swapping = false;
}
uint256 fees = 0;
// don't run this if it's currently _swapping, if either the sender or the reciever is fee exempt, or if it's not a buy or sell
if (!_swapping && !(_isFeeExempt[from] || _isFeeExempt[to]) && (pair == from || pair == to)) {
fees = amount * totalFee / denominator;
if (fees > 0) {
super._transfer(from, address(this), fees);
}
amount -= fees;
}
super._transfer(from, to, amount);
if (from != pair && !_isDividendExempt[from]) distributor.setShare(from, balanceOf(from));
if (to != pair && !_isDividendExempt[to]) distributor.setShare(to, balanceOf(to));
}
function _swapBack() private {
uint256 currentBalance = balanceOf(address(this));
uint256 liquidityFeeHalf = liquidityFee >> 1;
uint256 tokensForliquidity = currentBalance * liquidityFeeHalf / totalFee;
uint256 tokensToSwapForShia = currentBalance * printerFee / totalFee;
uint256 tokensToSwapForEth = currentBalance - tokensToSwapForShia - tokensForliquidity;
uint256 initialEthBalance = address(this).balance;
_swapTokensForEth(tokensToSwapForEth);
uint256 ethBalance = address(this).balance - initialEthBalance;
uint256 ethForLiquidity = ethBalance * liquidityFeeHalf / (liquidityFeeHalf + teamFee);
_addLiquidity(tokensForliquidity, ethForLiquidity);
_swapTokensForShia(tokensToSwapForShia);
uint256 shiaBalance = IERC20(SHIA).balanceOf(address(this));
bool success = IERC20(SHIA).transfer(address(distributor), shiaBalance);
if (success) {
distributor.deposit(shiaBalance);
}
(bool teamTransferSuccess,) = address(_teamWallet).call{value: address(this).balance}("");
require(teamTransferSuccess, "Failed to send ETH to team wallet");
}
function _swapTokensForShia(uint256 tokenAmount) private {
address[] memory path = new address[](3);
path[0] = address(this);
path[1] = WETH;
path[2] = SHIA;
// make the swap
router.swapExactTokensForTokens(tokenAmount, 0, path, address(this), block.timestamp);
}
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] = WETH;
// make the swap
router.swapExactTokensForETH(
tokenAmount,
0, // accept any amount of ETH
path,
address(this),
block.timestamp
);
}
function _addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
// add the liquidity
router.addLiquidityETH{value: ethAmount}(
address(this),
tokenAmount,
0, // slippage is unavoidable
0, // slippage is unavoidable
_teamWallet,
block.timestamp
);
}
function _setIsDividendExempt(address holder, bool exempt) internal {
require(holder != address(this) && holder != pair);
_isDividendExempt[holder] = exempt;
if (exempt) {
distributor.setShare(holder, 0);
} else {
distributor.setShare(holder, balanceOf(holder));
}
}
function setIsDividendExempt(address holder, bool exempt) external onlyOwner {
_setIsDividendExempt(holder, exempt);
}
function setIsFeeExempt(address holder, bool exempt) external onlyOwner {
_isFeeExempt[holder] = exempt;
}
function removeLimitsInEffect() external onlyOwner {
_limitsInEffect = false;
}
function setDividendDistributor(address _dividendDistributor) external onlyOwner {
distributor = IDividendDistributor(_dividendDistributor);
}
receive() external payable {}
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/ERC20.sol)
pragma solidity ^0.8.0;
import "./IERC20.sol";
import "./extensions/IERC20Metadata.sol";
import "../../utils/Context.sol";
/**
* @dev Implementation of the {IERC20} interface.
*
* This implementation is agnostic to the way tokens are created. This means
* that a supply mechanism has to be added in a derived contract using {_mint}.
* For a generic mechanism see {ERC20PresetMinterPauser}.
*
* TIP: For a detailed writeup see our guide
* https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
* to implement supply mechanisms].
*
* The default value of {decimals} is 18. To change this, you should override
* this function so it returns a different value.
*
* We have followed general OpenZeppelin Contracts guidelines: functions revert
* instead returning `false` on failure. This behavior is nonetheless
* conventional and does not conflict with the expectations of ERC20
* applications.
*
* Additionally, an {Approval} event is emitted on calls to {transferFrom}.
* This allows applications to reconstruct the allowance for all accounts just
* by listening to said events. Other implementations of the EIP may not emit
* these events, as it isn't required by the specification.
*
* Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
* functions have been added to mitigate the well-known issues around setting
* allowances. See {IERC20-approve}.
*/
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;
/**
* @dev Sets the values for {name} and {symbol}.
*
* All two of these values are immutable: they can only be set once during
* construction.
*/
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
/**
* @dev Returns the name of the token.
*/
function name() public view virtual override returns (string memory) {
return _name;
}
/**
* @dev Returns the symbol of the token, usually a shorter version of the
* name.
*/
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
/**
* @dev Returns the number of decimals used to get its user representation.
* For example, if `decimals` equals `2`, a balance of `505` tokens should
* be displayed to a user as `5.05` (`505 / 10 ** 2`).
*
* Tokens usually opt for a value of 18, imitating the relationship between
* Ether and Wei. This is the default value returned by this function, unless
* it's overridden.
*
* NOTE: This information is only used for _display_ purposes: it in
* no way affects any of the arithmetic of the contract, including
* {IERC20-balanceOf} and {IERC20-transfer}.
*/
function decimals() public view virtual override returns (uint8) {
return 18;
}
/**
* @dev See {IERC20-totalSupply}.
*/
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
/**
* @dev See {IERC20-balanceOf}.
*/
function balanceOf(address account) public view virtual override returns (uint256) {
return _balances[account];
}
/**
* @dev See {IERC20-transfer}.
*
* Requirements:
*
* - `to` cannot be the zero address.
* - the caller must have a balance of at least `amount`.
*/
function transfer(address to, uint256 amount) public virtual override returns (bool) {
address owner = _msgSender();
_transfer(owner, to, amount);
return true;
}
/**
* @dev See {IERC20-allowance}.
*/
function allowance(address owner, address spender) public view virtual override returns (uint256) {
return _allowances[owner][spender];
}
/**
* @dev See {IERC20-approve}.
*
* NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
* `transferFrom`. This is semantically equivalent to an infinite approval.
*
* Requirements:
*
* - `spender` cannot be the zero address.
*/
function approve(address spender, uint256 amount) public virtual override returns (bool) {
address owner = _msgSender();
_approve(owner, spender, amount);
return true;
}
/**
* @dev See {IERC20-transferFrom}.
*
* Emits an {Approval} event indicating the updated allowance. This is not
* required by the EIP. See the note at the beginning of {ERC20}.
*
* NOTE: Does not update the allowance if the current allowance
* is the maximum `uint256`.
*
* Requirements:
*
* - `from` and `to` cannot be the zero address.
* - `from` must have a balance of at least `amount`.
* - the caller must have allowance for ``from``'s tokens of at least
* `amount`.
*/
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;
}
/**
* @dev Atomically increases the allowance granted to `spender` by the caller.
*
* This is an alternative to {approve} that can be used as a mitigation for
* problems described in {IERC20-approve}.
*
* Emits an {Approval} event indicating the updated allowance.
*
* Requirements:
*
* - `spender` cannot be the zero address.
*/
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
address owner = _msgSender();
_approve(owner, spender, allowance(owner, spender) + addedValue);
return true;
}
/**
* @dev Atomically decreases the allowance granted to `spender` by the caller.
*
* This is an alternative to {approve} that can be used as a mitigation for
* problems described in {IERC20-approve}.
*
* Emits an {Approval} event indicating the updated allowance.
*
* Requirements:
*
* - `spender` cannot be the zero address.
* - `spender` must have allowance for the caller of at least
* `subtractedValue`.
*/
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
address owner = _msgSender();
uint256 currentAllowance = allowance(owner, spender);
require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
unchecked {
_approve(owner, spender, currentAllowance - subtractedValue);
}
return true;
}
/**
* @dev Moves `amount` of tokens from `from` to `to`.
*
* This internal function is equivalent to {transfer}, and can be used to
* e.g. implement automatic token fees, slashing mechanisms, etc.
*
* Emits a {Transfer} event.
*
* Requirements:
*
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
* - `from` must have a balance of at least `amount`.
*/
function _transfer(address from, address to, uint256 amount) internal virtual {
require(from != address(0), "ERC20: transfer 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;
// Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
// decrementing then incrementing.
_balances[to] += amount;
}
emit Transfer(from, to, amount);
_afterTokenTransfer(from, to, amount);
}
/** @dev Creates `amount` tokens and assigns them to `account`, increasing
* the total supply.
*
* Emits a {Transfer} event with `from` set to the zero address.
*
* Requirements:
*
* - `account` cannot be the zero address.
*/
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;
unchecked {
// Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
_balances[account] += amount;
}
emit Transfer(address(0), account, amount);
_afterTokenTransfer(address(0), account, amount);
}
/**
* @dev Destroys `amount` tokens from `account`, reducing the
* total supply.
*
* Emits a {Transfer} event with `to` set to the zero address.
*
* Requirements:
*
* - `account` cannot be the zero address.
* - `account` must have at least `amount` tokens.
*/
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;
// Overflow not possible: amount <= accountBalance <= totalSupply.
_totalSupply -= amount;
}
emit Transfer(account, address(0), amount);
_afterTokenTransfer(account, address(0), amount);
}
/**
* @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
*
* This internal function is equivalent to `approve`, and can be used to
* e.g. set automatic allowances for certain subsystems, etc.
*
* Emits an {Approval} event.
*
* Requirements:
*
* - `owner` cannot be the zero address.
* - `spender` cannot be the zero address.
*/
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);
}
/**
* @dev Updates `owner` s allowance for `spender` based on spent `amount`.
*
* Does not update the allowance amount in case of infinite allowance.
* Revert if not enough allowance is available.
*
* Might emit an {Approval} event.
*/
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);
}
}
}
/**
* @dev Hook that is called before any transfer of tokens. This includes
* minting and burning.
*
* Calling conditions:
*
* - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
* will be transferred to `to`.
* - when `from` is zero, `amount` tokens will be minted for `to`.
* - when `to` is zero, `amount` of ``from``'s tokens will be burned.
* - `from` and `to` are never both zero.
*
* To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
*/
function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual {}
/**
* @dev Hook that is called after any transfer of tokens. This includes
* minting and burning.
*
* Calling conditions:
*
* - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
* has been transferred to `to`.
* - when `from` is zero, `amount` tokens have been minted for `to`.
* - when `to` is zero, `amount` of ``from``'s tokens have been burned.
* - `from` and `to` are never both zero.
*
* To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
*/
function _afterTokenTransfer(address from, address to, uint256 amount) internal virtual {}
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)
pragma solidity ^0.8.0;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @dev Emitted when `value` tokens are moved from one account (`from`) to
* another (`to`).
*
* Note that `value` may be zero.
*/
event Transfer(address indexed from, address indexed to, uint256 value);
/**
* @dev Emitted when the allowance of a `spender` for an `owner` is set by
* a call to {approve}. `value` is the new allowance.
*/
event Approval(address indexed owner, address indexed spender, uint256 value);
/**
* @dev Returns the amount of tokens in existence.
*/
function totalSupply() external view returns (uint256);
/**
* @dev Returns the amount of tokens owned by `account`.
*/
function balanceOf(address account) external view returns (uint256);
/**
* @dev Moves `amount` tokens from the caller's account to `to`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address to, uint256 amount) external returns (bool);
/**
* @dev Returns the remaining number of tokens that `spender` will be
* allowed to spend on behalf of `owner` through {transferFrom}. This is
* zero by default.
*
* This value changes when {approve} or {transferFrom} are called.
*/
function allowance(address owner, address spender) external view returns (uint256);
/**
* @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* IMPORTANT: Beware that changing an allowance with this method brings the risk
* that someone may use both the old and the new allowance by unfortunate
* transaction ordering. One possible solution to mitigate this race
* condition is to first reduce the spender's allowance to 0 and set the
* desired value afterwards:
* https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
*
* Emits an {Approval} event.
*/
function approve(address spender, uint256 amount) external returns (bool);
/**
* @dev Moves `amount` tokens from `from` to `to` using the
* allowance mechanism. `amount` is then deducted from the caller's
* allowance.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transferFrom(address from, address to, uint256 amount) external returns (bool);
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol)
pragma solidity ^0.8.0;
import "../utils/Context.sol";
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* By default, the owner account will be the one that deploys the contract. This
* can later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
/**
* @dev Initializes the contract setting the deployer as the initial owner.
*/
constructor() {
_transferOwnership(_msgSender());
}
/**
* @dev Throws if called by any account other than the owner.
*/
modifier onlyOwner() {
_checkOwner();
_;
}
/**
* @dev Returns the address of the current owner.
*/
function owner() public view virtual returns (address) {
return _owner;
}
/**
* @dev Throws if the sender is not the owner.
*/
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
/**
* @dev Leaves the contract without owner. It will not be possible to call
* `onlyOwner` functions. Can only be called by the current owner.
*
* NOTE: Renouncing ownership will leave the contract without an owner,
* thereby disabling any functionality that is only available to the owner.
*/
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Can only be called by the current owner.
*/
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Internal function without access restriction.
*/
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}pragma solidity >=0.5.0;
interface IUniswapV2Factory {
event PairCreated(address indexed token0, address indexed token1, address pair, uint);
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(uint) external view returns (address pair);
function allPairsLength() external view returns (uint);
function createPair(address tokenA, address tokenB) external returns (address pair);
function setFeeTo(address) external;
function setFeeToSetter(address) external;
}pragma solidity >=0.6.2;
import './IUniswapV2Router01.sol';
interface IUniswapV2Router02 is IUniswapV2Router01 {
function removeLiquidityETHSupportingFeeOnTransferTokens(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountETH);
function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountETH);
function swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external payable;
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
}pragma solidity >=0.5.0;
interface IUniswapV2Pair {
event Approval(address indexed owner, address indexed spender, uint value);
event Transfer(address indexed from, address indexed to, uint 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 (uint);
function balanceOf(address owner) external view returns (uint);
function allowance(address owner, address spender) external view returns (uint);
function approve(address spender, uint value) external returns (bool);
function transfer(address to, uint value) external returns (bool);
function transferFrom(address from, address to, uint 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 (uint);
function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
event Mint(address indexed sender, uint amount0, uint amount1);
event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
event Swap(
address indexed sender,
uint amount0In,
uint amount1In,
uint amount0Out,
uint amount1Out,
address indexed to
);
event Sync(uint112 reserve0, uint112 reserve1);
function MINIMUM_LIQUIDITY() external pure returns (uint);
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 (uint);
function price1CumulativeLast() external view returns (uint);
function kLast() external view returns (uint);
function mint(address to) external returns (uint liquidity);
function burn(address to) external returns (uint amount0, uint amount1);
function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
function skim(address to) external;
function sync() external;
function initialize(address, address) external;
}// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;
interface IDividendDistributor {
function setShare(address shareholderAddress, uint256 amount) external;
function deposit(uint256 amount) external;
function claimDividend() external;
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)
pragma solidity ^0.8.0;
import "../IERC20.sol";
/**
* @dev Interface for the optional metadata functions from the ERC20 standard.
*
* _Available since v4.1._
*/
interface IERC20Metadata is IERC20 {
/**
* @dev Returns the name of the token.
*/
function name() external view returns (string memory);
/**
* @dev Returns the symbol of the token.
*/
function symbol() external view returns (string memory);
/**
* @dev Returns the decimals places of the token.
*/
function decimals() external view returns (uint8);
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
pragma solidity ^0.8.0;
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
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.6.2;
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);
function removeLiquidityWithPermit(
address tokenA,
address tokenB,
uint liquidity,
uint amountAMin,
uint amountBMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountA, uint amountB);
function removeLiquidityETHWithPermit(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountToken, uint amountETH);
function swapExactTokensForTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapTokensForExactTokens(
uint amountOut,
uint amountInMax,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
external
payable
returns (uint[] memory amounts);
function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
external
payable
returns (uint[] memory amounts);
function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}{
"remappings": [
"ds-test/=lib/forge-std/lib/ds-test/src/",
"erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/",
"forge-std/=lib/forge-std/src/",
"openzeppelin-contracts/=lib/openzeppelin-contracts/",
"openzeppelin/=lib/openzeppelin-contracts/contracts/",
"v2-core/=lib/v2-core/contracts/",
"v2-periphery/=lib/v2-periphery/contracts/"
],
"optimizer": {
"enabled": true,
"runs": 200
},
"metadata": {
"useLiteralContent": false,
"bytecodeHash": "ipfs",
"appendCBOR": true
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
},
"evmVersion": "paris",
"libraries": {}
}Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"address","name":"teamWallet","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"MAX_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_TRANSACTION_AMOUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_WALLET","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SHIA","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SWAP_TOKENS_AT_AMOUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"denominator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"printerFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimitsInEffect","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_dividendDistributor","type":"address"}],"name":"setDividendDistributor","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsDividendExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsFeeExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"teamFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]Contract Creation Code
6101006040527343d7e65b8ff49698d9550a7f315c87e67344fb596080526014600a818155600b829055600c819055906200003b908062000674565b62000047919062000674565b600d556103e8600e556012805460ff60a01b1916600160a01b1790553480156200007057600080fd5b506040516200264b3803806200264b833981016040819052620000939162000690565b6040518060400160405280600b81526020016a29b434b0a83934b73a32b960a91b81525060405180604001604052806005815260200164053484941760dc1b8152508160039081620000e6919062000766565b506004620000f5828262000766565b505050620001126200010c6200041460201b60201c565b62000418565b600f80546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d908117909155604080516315ab88c960e31b8152905163ad5c4648916004808201926020929091908290030181865afa15801562000177573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200019d919062000690565b600680546001600160a01b0319166001600160a01b03928316179055600f546040805163c45a015560e01b81529051919092169163c45a01559160048083019260209291908290030181865afa158015620001fc573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000222919062000690565b6006546040516364e329cb60e11b81526001600160a01b03918216600482015230602482015291169063c9c65396906044016020604051808303816000875af115801562000274573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029a919062000690565b601080546001600160a01b0319166001600160a01b03929092169190911790556107d0620002d66b204fce5e3e25026110000000600a62000832565b620002e291906200084c565b60a052620002fe60646b204fce5e3e250261100000006200084c565b60c05260646200031c6b204fce5e3e25026110000000600262000832565b6200032891906200084c565b60e052601180546001600160a01b0319166001600160a01b038381169182179092556000818152600760209081526040808320805460ff199081166001908117909255338086528386208054831684179055600f80548916875284872080548416851790553080885285882080548516861790556010548a16885260098752858820805485168617905580885285882080548516861790559187526008909552838620805483168417905595855291909320805490911690921790915554620003f592166000196200046a565b6200040d336b204fce5e3e2502611000000062000596565b506200086f565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038316620004d25760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084015b60405180910390fd5b6001600160a01b038216620005355760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401620004c9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038216620005ee5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004c9565b806002600082825462000602919062000674565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b505050565b634e487b7160e01b600052601160045260246000fd5b808201808211156200068a576200068a6200065e565b92915050565b600060208284031215620006a357600080fd5b81516001600160a01b0381168114620006bb57600080fd5b9392505050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620006ed57607f821691505b6020821081036200070e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200065957600081815260208120601f850160051c810160208610156200073d5750805b601f850160051c820191505b818110156200075e5782815560010162000749565b505050505050565b81516001600160401b03811115620007825762000782620006c2565b6200079a81620007938454620006d8565b8462000714565b602080601f831160018114620007d25760008415620007b95750858301515b600019600386901b1c1916600185901b1785556200075e565b600085815260208120601f198616915b828110156200080357888601518255948401946001909101908401620007e2565b5085821015620008225787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b80820281158282048414176200068a576200068a6200065e565b6000826200086a57634e487b7160e01b600052601260045260246000fd5b500490565b60805160a05160c05160e051611d6a620008e16000396000818161051601528181610baf0152610d1d0152600081816105aa01528181610b190152610c670152600081816102ba0152610da201526000818161024a015281816114990152818161153b01526118e40152611d6a6000f3fe6080604052600436106101d15760003560e01c8063715018a6116100f7578063a9059cbb11610095578063f2fde38b11610064578063f2fde38b14610538578063f708a64f14610558578063f887ea4014610578578063f896c48d1461059857600080fd5b8063a9059cbb146104ae578063d7c94efd146104ce578063dd62ed3e146104e4578063df7787a41461050457600080fd5b806396ce0795116100d157806396ce07951461044257806398118cb414610458578063a457c2d71461046e578063a8aa1b311461048e57600080fd5b8063715018a6146103fa5780638da5cb5b1461040f57806395d89b411461042d57600080fd5b806323b872dd1161016f578063395093511161013e578063395093511461038557806353ab508c146103a5578063658d4b7f146103ba57806370a08231146103da57600080fd5b806323b872dd14610307578063313ce5671461032757806332516d481461034357806332cb6b0c1461036557600080fd5b806315d68174116101ab57806315d681741461028457806316dd23d2146102a857806318160ddd146102dc5780631df4ccfc146102f157600080fd5b806306fdde03146101dd578063095ea7b31461020857806312fb41871461023857600080fd5b366101d857005b600080fd5b3480156101e957600080fd5b506101f26105cc565b6040516101ff919061195c565b60405180910390f35b34801561021457600080fd5b506102286102233660046119c6565b61065e565b60405190151581526020016101ff565b34801561024457600080fd5b5061026c7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016101ff565b34801561029057600080fd5b5061029a600b5481565b6040519081526020016101ff565b3480156102b457600080fd5b5061029a7f000000000000000000000000000000000000000000000000000000000000000081565b3480156102e857600080fd5b5060025461029a565b3480156102fd57600080fd5b5061029a600d5481565b34801561031357600080fd5b506102286103223660046119f0565b610678565b34801561033357600080fd5b50604051601281526020016101ff565b34801561034f57600080fd5b5061036361035e366004611a2c565b61069c565b005b34801561037157600080fd5b5061029a6b204fce5e3e2502611000000081565b34801561039157600080fd5b506102286103a03660046119c6565b6106c6565b3480156103b157600080fd5b506103636106e8565b3480156103c657600080fd5b506103636103d5366004611a5c565b6106ff565b3480156103e657600080fd5b5061029a6103f5366004611a2c565b610732565b34801561040657600080fd5b5061036361074d565b34801561041b57600080fd5b506005546001600160a01b031661026c565b34801561043957600080fd5b506101f2610761565b34801561044e57600080fd5b5061029a600e5481565b34801561046457600080fd5b5061029a600c5481565b34801561047a57600080fd5b506102286104893660046119c6565b610770565b34801561049a57600080fd5b5060105461026c906001600160a01b031681565b3480156104ba57600080fd5b506102286104c93660046119c6565b6107f0565b3480156104da57600080fd5b5061029a600a5481565b3480156104f057600080fd5b5061029a6104ff366004611a93565b6107fe565b34801561051057600080fd5b5061029a7f000000000000000000000000000000000000000000000000000000000000000081565b34801561054457600080fd5b50610363610553366004611a2c565b610829565b34801561056457600080fd5b50610363610573366004611a5c565b6108a2565b34801561058457600080fd5b50600f5461026c906001600160a01b031681565b3480156105a457600080fd5b5061029a7f000000000000000000000000000000000000000000000000000000000000000081565b6060600380546105db90611ac6565b80601f016020809104026020016040519081016040528092919081815260200182805461060790611ac6565b80156106545780601f1061062957610100808354040283529160200191610654565b820191906000526020600020905b81548152906001019060200180831161063757829003601f168201915b5050505050905090565b60003361066c8185856108b8565b60019150505b92915050565b6000336106868582856109dc565b610691858585610a56565b506001949350505050565b6106a461106b565b601280546001600160a01b0319166001600160a01b0392909216919091179055565b60003361066c8185856106d983836107fe565b6106e39190611b16565b6108b8565b6106f061106b565b6012805460ff60a01b19169055565b61070761106b565b6001600160a01b03919091166000908152600760205260409020805460ff1916911515919091179055565b6001600160a01b031660009081526020819052604090205490565b61075561106b565b61075f60006110c5565b565b6060600480546105db90611ac6565b6000338161077e82866107fe565b9050838110156107e35760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61069182868684036108b8565b60003361066c818585610a56565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61083161106b565b6001600160a01b0381166108965760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107da565b61089f816110c5565b50565b6108aa61106b565b6108b48282611117565b5050565b6001600160a01b03831661091a5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107da565b6001600160a01b03821661097b5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107da565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006109e884846107fe565b90506000198114610a505781811015610a435760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016107da565b610a5084848484036108b8565b50505050565b80600003610a6f57610a6a83836000611223565b505050565b601254600160a01b900460ff1615610d93576005546001600160a01b03848116911614801590610aad57506005546001600160a01b03838116911614155b8015610ac157506001600160a01b03821615155b8015610ad75750601254600160a81b900460ff16155b15610d93576010546001600160a01b038481169116148015610b1257506001600160a01b03821660009081526008602052604090205460ff16155b15610c2a577f0000000000000000000000000000000000000000000000000000000000000000811115610bad5760405162461bcd60e51b815260206004820152603760248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527f6d6178207472616e73616374696f6e20616d6f756e742e00000000000000000060648201526084016107da565b7f0000000000000000000000000000000000000000000000000000000000000000610bd783610732565b610be19083611b16565b1115610c255760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107da565b610d93565b6010546001600160a01b038381169116148015610c6057506001600160a01b03831660009081526008602052604090205460ff16155b15610cfb577f0000000000000000000000000000000000000000000000000000000000000000811115610c255760405162461bcd60e51b815260206004820152603860248201527f53656c6c207472616e7366657220616d6f756e7420657863656564732074686560448201527f206d6178207472616e73616374696f6e20616d6f756e742e000000000000000060648201526084016107da565b6001600160a01b03821660009081526008602052604090205460ff16610d93577f0000000000000000000000000000000000000000000000000000000000000000610d4583610732565b610d4f9083611b16565b1115610d935760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107da565b6000610d9e30610732565b90507f000000000000000000000000000000000000000000000000000000000000000081108015908190610ddc5750601254600160a81b900460ff16155b8015610df657506010546001600160a01b03868116911614155b15610e24576012805460ff60a81b1916600160a81b179055610e166113c7565b6012805460ff60a81b191690555b601254600090600160a81b900460ff16158015610e7d57506001600160a01b03861660009081526007602052604090205460ff1680610e7b57506001600160a01b03851660009081526007602052604090205460ff165b155b8015610ead57506010546001600160a01b0387811691161480610ead57506010546001600160a01b038681169116145b15610eec57600e54600d54610ec29086611b29565b610ecc9190611b40565b90508015610edf57610edf863083611223565b610ee98185611b62565b93505b610ef7868686611223565b6010546001600160a01b03878116911614801590610f2e57506001600160a01b03861660009081526009602052604090205460ff16155b15610fad576012546001600160a01b03166314b6ca9687610f4e81610732565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b158015610f9457600080fd5b505af1158015610fa8573d6000803e3d6000fd5b505050505b6010546001600160a01b03868116911614801590610fe457506001600160a01b03851660009081526009602052604090205460ff16155b15611063576012546001600160a01b03166314b6ca968661100481610732565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b15801561104a57600080fd5b505af115801561105e573d6000803e3d6000fd5b505050505b505050505050565b6005546001600160a01b0316331461075f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107da565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216301480159061113e57506010546001600160a01b03838116911614155b61114757600080fd5b6001600160a01b0382166000908152600960205260409020805460ff191682158015919091179091556111d757601254604051630a5b654b60e11b81526001600160a01b03848116600483015260006024830152909116906314b6ca96906044015b600060405180830381600087803b1580156111c357600080fd5b505af1158015611063573d6000803e3d6000fd5b6012546001600160a01b03166314b6ca96836111f281610732565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016111a9565b6001600160a01b0383166112875760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107da565b6001600160a01b0382166112e95760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107da565b6001600160a01b038316600090815260208190526040902054818110156113615760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016107da565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610a50565b60006113d230610732565b600c54600d5491925060011c906000906113ec8385611b29565b6113f69190611b40565b90506000600d54600b548561140b9190611b29565b6114159190611b40565b90506000826114248387611b62565b61142e9190611b62565b90504761143a826116cb565b60006114468247611b62565b90506000600a54876114589190611b16565b6114628884611b29565b61146c9190611b40565b905061147886826117be565b6114818561185a565b6040516370a0823160e01b81523060048201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316906370a0823190602401602060405180830381865afa1580156114e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061150c9190611b75565b60125460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018390529192506000917f00000000000000000000000000000000000000000000000000000000000000009091169063a9059cbb906044016020604051808303816000875af1158015611586573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115aa9190611b8e565b905080156116115760125460405163b6b55f2560e01b8152600481018490526001600160a01b039091169063b6b55f2590602401600060405180830381600087803b1580156115f857600080fd5b505af115801561160c573d6000803e3d6000fd5b505050505b6011546040516000916001600160a01b03169047908381818185875af1925050503d806000811461165e576040519150601f19603f3d011682016040523d82523d6000602084013e611663565b606091505b50509050806116be5760405162461bcd60e51b815260206004820152602160248201527f4661696c656420746f2073656e642045544820746f207465616d2077616c6c656044820152601d60fa1b60648201526084016107da565b5050505050505050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061170057611700611bc1565b6001600160a01b03928316602091820292909201015260065482519116908290600190811061173157611731611bc1565b6001600160a01b039283166020918202929092010152600f546040516318cbafe560e01b81529116906318cbafe590611777908590600090869030904290600401611bd7565b6000604051808303816000875af1158015611796573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610a6a9190810190611c48565b600f5460115460405163f305d71960e01b81523060048201526024810185905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af115801561182e573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906118539190611d06565b5050505050565b6040805160038082526080820190925260009160208201606080368337019050509050308160008151811061189157611891611bc1565b6001600160a01b0392831660209182029290920101526006548251911690829060019081106118c2576118c2611bc1565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000008160028151811061191657611916611bc1565b6001600160a01b039283166020918202929092010152600f546040516338ed173960e01b81529116906338ed173990611777908590600090869030904290600401611bd7565b600060208083528351808285015260005b818110156119895785810183015185820160400152820161196d565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b03811681146119c157600080fd5b919050565b600080604083850312156119d957600080fd5b6119e2836119aa565b946020939093013593505050565b600080600060608486031215611a0557600080fd5b611a0e846119aa565b9250611a1c602085016119aa565b9150604084013590509250925092565b600060208284031215611a3e57600080fd5b611a47826119aa565b9392505050565b801515811461089f57600080fd5b60008060408385031215611a6f57600080fd5b611a78836119aa565b91506020830135611a8881611a4e565b809150509250929050565b60008060408385031215611aa657600080fd5b611aaf836119aa565b9150611abd602084016119aa565b90509250929050565b600181811c90821680611ada57607f821691505b602082108103611afa57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561067257610672611b00565b808202811582820484141761067257610672611b00565b600082611b5d57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561067257610672611b00565b600060208284031215611b8757600080fd5b5051919050565b600060208284031215611ba057600080fd5b8151611a4781611a4e565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c275784516001600160a01b031683529383019391830191600101611c02565b50506001600160a01b03969096166060850152505050608001529392505050565b60006020808385031215611c5b57600080fd5b825167ffffffffffffffff80821115611c7357600080fd5b818501915085601f830112611c8757600080fd5b815181811115611c9957611c99611bab565b8060051b604051601f19603f83011681018181108582111715611cbe57611cbe611bab565b604052918252848201925083810185019188831115611cdc57600080fd5b938501935b82851015611cfa57845184529385019392850192611ce1565b98975050505050505050565b600080600060608486031215611d1b57600080fd5b835192506020840151915060408401519050925092509256fea2646970667358221220ed84d0e55a0c74805dc4be531b07b5c8f37a6cab736ed6f79210c59466a15a1f64736f6c6343000815003300000000000000000000000089a35af5ae2b22c46b22a64110d63f2fcc8a7f02
Deployed Bytecode
0x6080604052600436106101d15760003560e01c8063715018a6116100f7578063a9059cbb11610095578063f2fde38b11610064578063f2fde38b14610538578063f708a64f14610558578063f887ea4014610578578063f896c48d1461059857600080fd5b8063a9059cbb146104ae578063d7c94efd146104ce578063dd62ed3e146104e4578063df7787a41461050457600080fd5b806396ce0795116100d157806396ce07951461044257806398118cb414610458578063a457c2d71461046e578063a8aa1b311461048e57600080fd5b8063715018a6146103fa5780638da5cb5b1461040f57806395d89b411461042d57600080fd5b806323b872dd1161016f578063395093511161013e578063395093511461038557806353ab508c146103a5578063658d4b7f146103ba57806370a08231146103da57600080fd5b806323b872dd14610307578063313ce5671461032757806332516d481461034357806332cb6b0c1461036557600080fd5b806315d68174116101ab57806315d681741461028457806316dd23d2146102a857806318160ddd146102dc5780631df4ccfc146102f157600080fd5b806306fdde03146101dd578063095ea7b31461020857806312fb41871461023857600080fd5b366101d857005b600080fd5b3480156101e957600080fd5b506101f26105cc565b6040516101ff919061195c565b60405180910390f35b34801561021457600080fd5b506102286102233660046119c6565b61065e565b60405190151581526020016101ff565b34801561024457600080fd5b5061026c7f00000000000000000000000043d7e65b8ff49698d9550a7f315c87e67344fb5981565b6040516001600160a01b0390911681526020016101ff565b34801561029057600080fd5b5061029a600b5481565b6040519081526020016101ff565b3480156102b457600080fd5b5061029a7f000000000000000000000000000000000000000000295be96e6406697200000081565b3480156102e857600080fd5b5060025461029a565b3480156102fd57600080fd5b5061029a600d5481565b34801561031357600080fd5b506102286103223660046119f0565b610678565b34801561033357600080fd5b50604051601281526020016101ff565b34801561034f57600080fd5b5061036361035e366004611a2c565b61069c565b005b34801561037157600080fd5b5061029a6b204fce5e3e2502611000000081565b34801561039157600080fd5b506102286103a03660046119c6565b6106c6565b3480156103b157600080fd5b506103636106e8565b3480156103c657600080fd5b506103636103d5366004611a5c565b6106ff565b3480156103e657600080fd5b5061029a6103f5366004611a2c565b610732565b34801561040657600080fd5b5061036361074d565b34801561041b57600080fd5b506005546001600160a01b031661026c565b34801561043957600080fd5b506101f2610761565b34801561044e57600080fd5b5061029a600e5481565b34801561046457600080fd5b5061029a600c5481565b34801561047a57600080fd5b506102286104893660046119c6565b610770565b34801561049a57600080fd5b5060105461026c906001600160a01b031681565b3480156104ba57600080fd5b506102286104c93660046119c6565b6107f0565b3480156104da57600080fd5b5061029a600a5481565b3480156104f057600080fd5b5061029a6104ff366004611a93565b6107fe565b34801561051057600080fd5b5061029a7f000000000000000000000000000000000000000000a56fa5b99019a5c800000081565b34801561054457600080fd5b50610363610553366004611a2c565b610829565b34801561056457600080fd5b50610363610573366004611a5c565b6108a2565b34801561058457600080fd5b50600f5461026c906001600160a01b031681565b3480156105a457600080fd5b5061029a7f00000000000000000000000000000000000000000052b7d2dcc80cd2e400000081565b6060600380546105db90611ac6565b80601f016020809104026020016040519081016040528092919081815260200182805461060790611ac6565b80156106545780601f1061062957610100808354040283529160200191610654565b820191906000526020600020905b81548152906001019060200180831161063757829003601f168201915b5050505050905090565b60003361066c8185856108b8565b60019150505b92915050565b6000336106868582856109dc565b610691858585610a56565b506001949350505050565b6106a461106b565b601280546001600160a01b0319166001600160a01b0392909216919091179055565b60003361066c8185856106d983836107fe565b6106e39190611b16565b6108b8565b6106f061106b565b6012805460ff60a01b19169055565b61070761106b565b6001600160a01b03919091166000908152600760205260409020805460ff1916911515919091179055565b6001600160a01b031660009081526020819052604090205490565b61075561106b565b61075f60006110c5565b565b6060600480546105db90611ac6565b6000338161077e82866107fe565b9050838110156107e35760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61069182868684036108b8565b60003361066c818585610a56565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61083161106b565b6001600160a01b0381166108965760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107da565b61089f816110c5565b50565b6108aa61106b565b6108b48282611117565b5050565b6001600160a01b03831661091a5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107da565b6001600160a01b03821661097b5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107da565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006109e884846107fe565b90506000198114610a505781811015610a435760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016107da565b610a5084848484036108b8565b50505050565b80600003610a6f57610a6a83836000611223565b505050565b601254600160a01b900460ff1615610d93576005546001600160a01b03848116911614801590610aad57506005546001600160a01b03838116911614155b8015610ac157506001600160a01b03821615155b8015610ad75750601254600160a81b900460ff16155b15610d93576010546001600160a01b038481169116148015610b1257506001600160a01b03821660009081526008602052604090205460ff16155b15610c2a577f00000000000000000000000000000000000000000052b7d2dcc80cd2e4000000811115610bad5760405162461bcd60e51b815260206004820152603760248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527f6d6178207472616e73616374696f6e20616d6f756e742e00000000000000000060648201526084016107da565b7f000000000000000000000000000000000000000000a56fa5b99019a5c8000000610bd783610732565b610be19083611b16565b1115610c255760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107da565b610d93565b6010546001600160a01b038381169116148015610c6057506001600160a01b03831660009081526008602052604090205460ff16155b15610cfb577f00000000000000000000000000000000000000000052b7d2dcc80cd2e4000000811115610c255760405162461bcd60e51b815260206004820152603860248201527f53656c6c207472616e7366657220616d6f756e7420657863656564732074686560448201527f206d6178207472616e73616374696f6e20616d6f756e742e000000000000000060648201526084016107da565b6001600160a01b03821660009081526008602052604090205460ff16610d93577f000000000000000000000000000000000000000000a56fa5b99019a5c8000000610d4583610732565b610d4f9083611b16565b1115610d935760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107da565b6000610d9e30610732565b90507f000000000000000000000000000000000000000000295be96e6406697200000081108015908190610ddc5750601254600160a81b900460ff16155b8015610df657506010546001600160a01b03868116911614155b15610e24576012805460ff60a81b1916600160a81b179055610e166113c7565b6012805460ff60a81b191690555b601254600090600160a81b900460ff16158015610e7d57506001600160a01b03861660009081526007602052604090205460ff1680610e7b57506001600160a01b03851660009081526007602052604090205460ff165b155b8015610ead57506010546001600160a01b0387811691161480610ead57506010546001600160a01b038681169116145b15610eec57600e54600d54610ec29086611b29565b610ecc9190611b40565b90508015610edf57610edf863083611223565b610ee98185611b62565b93505b610ef7868686611223565b6010546001600160a01b03878116911614801590610f2e57506001600160a01b03861660009081526009602052604090205460ff16155b15610fad576012546001600160a01b03166314b6ca9687610f4e81610732565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b158015610f9457600080fd5b505af1158015610fa8573d6000803e3d6000fd5b505050505b6010546001600160a01b03868116911614801590610fe457506001600160a01b03851660009081526009602052604090205460ff16155b15611063576012546001600160a01b03166314b6ca968661100481610732565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b15801561104a57600080fd5b505af115801561105e573d6000803e3d6000fd5b505050505b505050505050565b6005546001600160a01b0316331461075f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107da565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216301480159061113e57506010546001600160a01b03838116911614155b61114757600080fd5b6001600160a01b0382166000908152600960205260409020805460ff191682158015919091179091556111d757601254604051630a5b654b60e11b81526001600160a01b03848116600483015260006024830152909116906314b6ca96906044015b600060405180830381600087803b1580156111c357600080fd5b505af1158015611063573d6000803e3d6000fd5b6012546001600160a01b03166314b6ca96836111f281610732565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016111a9565b6001600160a01b0383166112875760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107da565b6001600160a01b0382166112e95760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107da565b6001600160a01b038316600090815260208190526040902054818110156113615760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016107da565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610a50565b60006113d230610732565b600c54600d5491925060011c906000906113ec8385611b29565b6113f69190611b40565b90506000600d54600b548561140b9190611b29565b6114159190611b40565b90506000826114248387611b62565b61142e9190611b62565b90504761143a826116cb565b60006114468247611b62565b90506000600a54876114589190611b16565b6114628884611b29565b61146c9190611b40565b905061147886826117be565b6114818561185a565b6040516370a0823160e01b81523060048201526000907f00000000000000000000000043d7e65b8ff49698d9550a7f315c87e67344fb596001600160a01b0316906370a0823190602401602060405180830381865afa1580156114e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061150c9190611b75565b60125460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018390529192506000917f00000000000000000000000043d7e65b8ff49698d9550a7f315c87e67344fb599091169063a9059cbb906044016020604051808303816000875af1158015611586573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115aa9190611b8e565b905080156116115760125460405163b6b55f2560e01b8152600481018490526001600160a01b039091169063b6b55f2590602401600060405180830381600087803b1580156115f857600080fd5b505af115801561160c573d6000803e3d6000fd5b505050505b6011546040516000916001600160a01b03169047908381818185875af1925050503d806000811461165e576040519150601f19603f3d011682016040523d82523d6000602084013e611663565b606091505b50509050806116be5760405162461bcd60e51b815260206004820152602160248201527f4661696c656420746f2073656e642045544820746f207465616d2077616c6c656044820152601d60fa1b60648201526084016107da565b5050505050505050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061170057611700611bc1565b6001600160a01b03928316602091820292909201015260065482519116908290600190811061173157611731611bc1565b6001600160a01b039283166020918202929092010152600f546040516318cbafe560e01b81529116906318cbafe590611777908590600090869030904290600401611bd7565b6000604051808303816000875af1158015611796573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610a6a9190810190611c48565b600f5460115460405163f305d71960e01b81523060048201526024810185905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af115801561182e573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906118539190611d06565b5050505050565b6040805160038082526080820190925260009160208201606080368337019050509050308160008151811061189157611891611bc1565b6001600160a01b0392831660209182029290920101526006548251911690829060019081106118c2576118c2611bc1565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000043d7e65b8ff49698d9550a7f315c87e67344fb598160028151811061191657611916611bc1565b6001600160a01b039283166020918202929092010152600f546040516338ed173960e01b81529116906338ed173990611777908590600090869030904290600401611bd7565b600060208083528351808285015260005b818110156119895785810183015185820160400152820161196d565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b03811681146119c157600080fd5b919050565b600080604083850312156119d957600080fd5b6119e2836119aa565b946020939093013593505050565b600080600060608486031215611a0557600080fd5b611a0e846119aa565b9250611a1c602085016119aa565b9150604084013590509250925092565b600060208284031215611a3e57600080fd5b611a47826119aa565b9392505050565b801515811461089f57600080fd5b60008060408385031215611a6f57600080fd5b611a78836119aa565b91506020830135611a8881611a4e565b809150509250929050565b60008060408385031215611aa657600080fd5b611aaf836119aa565b9150611abd602084016119aa565b90509250929050565b600181811c90821680611ada57607f821691505b602082108103611afa57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561067257610672611b00565b808202811582820484141761067257610672611b00565b600082611b5d57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561067257610672611b00565b600060208284031215611b8757600080fd5b5051919050565b600060208284031215611ba057600080fd5b8151611a4781611a4e565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c275784516001600160a01b031683529383019391830191600101611c02565b50506001600160a01b03969096166060850152505050608001529392505050565b60006020808385031215611c5b57600080fd5b825167ffffffffffffffff80821115611c7357600080fd5b818501915085601f830112611c8757600080fd5b815181811115611c9957611c99611bab565b8060051b604051601f19603f83011681018181108582111715611cbe57611cbe611bab565b604052918252848201925083810185019188831115611cdc57600080fd5b938501935b82851015611cfa57845184529385019392850192611ce1565b98975050505050505050565b600080600060608486031215611d1b57600080fd5b835192506020840151915060408401519050925092509256fea2646970667358221220ed84d0e55a0c74805dc4be531b07b5c8f37a6cab736ed6f79210c59466a15a1f64736f6c63430008150033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000089a35af5ae2b22c46b22a64110d63f2fcc8a7f02
-----Decoded View---------------
Arg [0] : teamWallet (address): 0x89a35AF5ae2B22c46b22a64110d63F2FcC8a7F02
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 00000000000000000000000089a35af5ae2b22c46b22a64110d63f2fcc8a7f02
Loading...
Loading
Loading...
Loading
Net Worth in USD
$0.00
Net Worth in ETH
0
Multichain Portfolio | 33 Chains
| Chain | Token | Portfolio % | Price | Amount | Value |
|---|
Loading...
Loading
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.