Source Code
More Info
Private Name Tags
ContractCreator
TokenTracker
Latest 9 from a total of 9 transactions
| Transaction Hash |
Method
|
Block
|
From
|
|
To
|
||||
|---|---|---|---|---|---|---|---|---|---|
| Transfer Ownersh... | 20641690 | 551 days ago | IN | 0 ETH | 0.00010724 | ||||
| Remove Limits | 20641685 | 551 days ago | IN | 0 ETH | 0.00006903 | ||||
| Update Dev Walle... | 20641682 | 551 days ago | IN | 0 ETH | 0.00007332 | ||||
| Update Dev Walle... | 20641615 | 551 days ago | IN | 0 ETH | 0.00005635 | ||||
| Exclude From Fee... | 20641596 | 551 days ago | IN | 0 ETH | 0.00008647 | ||||
| Exclude From Max... | 20641591 | 551 days ago | IN | 0 ETH | 0.00008118 | ||||
| Enable Trading | 20641402 | 551 days ago | IN | 0 ETH | 0.00003987 | ||||
| Set Automated Ma... | 20641400 | 551 days ago | IN | 0 ETH | 0.00006892 | ||||
| Approve | 20641393 | 551 days ago | IN | 0 ETH | 0.00008348 |
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions
Loading...
Loading
Contract Name:
EmpireCity
Compiler Version
v0.8.20+commit.a1b79de6
Optimization Enabled:
Yes with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
/*
______ _ _____ _ _
| ____| (_) / ____(_) |
| |__ _ __ ___ _ __ _ _ __ ___ | | _| |_ _ _
| __| | '_ ` _ \| '_ \| | '__/ _ \ | | | | __| | | |
| |____| | | | | | |_) | | | | __/ | |____| | |_| |_| |
|______|_| |_| |_| .__/|_|_| \___| \_____|_|\__|\__, |
| | __/ |
|_| |___/
● Revolutionary ERC-20
● Deflationary supply
● Fast games secured by Chainlink VRF
Website: https://empire-city.site/
Documentation: https://docs.empire-city.site/
Telegram: https://t.me/empirecityeth/
X (Twitter): https://x.com/empirecityeth/
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import {VRFConsumerBaseV2Plus} from "@chainlink/contracts@1.2.0/src/v0.8/vrf/dev/VRFConsumerBaseV2Plus.sol";
import {VRFV2PlusClient} from "@chainlink/contracts@1.2.0/src/v0.8/vrf/dev/libraries/VRFV2PlusClient.sol";
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
return msg.data;
}
}
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;
}
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;
}
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);
}
interface IERC20Metadata is IERC20 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
}
contract ERC20 is Context, IERC20, IERC20Metadata {
mapping(address => uint256) private _balances;
mapping(address => mapping(address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
function name() public view virtual override returns (string memory) {
return _name;
}
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
function decimals() public view virtual override returns (uint8) {
return 18;
}
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view virtual override returns (uint256) {
return _balances[account];
}
function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender) public view virtual override returns (uint256) {
return _allowances[owner][spender];
}
function approve(address spender, uint256 amount) public virtual override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public virtual override returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()] - amount );
return true;
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue );
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] - subtractedValue );
return true;
}
function _transfer(
address sender,
address recipient,
uint256 amount
) internal virtual {
require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
_beforeTokenTransfer(sender, recipient, amount);
_balances[sender] = _balances[sender] - amount;
_balances[recipient] = _balances[recipient] + amount;
emit Transfer(sender, recipient, amount);
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply = _totalSupply + amount;
_balances[account] = _balances[account] + amount;
emit Transfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
_balances[account] = _balances[account] - amount;
_totalSupply = _totalSupply - amount;
emit Transfer(account, address(0), amount);
}
function _approve(
address owner,
address spender,
uint256 amount
) internal virtual {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
}
contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor () {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
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);
}
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;
}
error Reentrancy();
abstract contract ReentrancyGuard {
uint256 private locked = 1;
modifier nonReentrant() {
if (locked != 1) {
revert Reentrancy();
}
locked = 2;
_;
locked = 1;
}
}
contract EmpireCity is ERC20, ReentrancyGuard, VRFConsumerBaseV2Plus {
uint256 private s_subscriptionId;
bytes32 private keyHash;
uint32 private callbackGasLimit = 2500000;
uint16 private requestConfirmations = 3;
uint32 private numWords = 1;
mapping(uint256 => address) private requestIdToSender;
mapping(address => uint256) public userIdFlip;
mapping(address => uint256) public betsizeFlip;
event betFlip(address indexed from, uint amount);
event winFlip(address indexed from, uint roll, bool won, uint amount);
IUniswapV2Router02 public uniswapV2Router;
address public constant deadAddress = address(0xdead);
bool private swapping;
address public devWallet;
uint256 public maxTransactionAmount;
uint256 public swapTokensAtAmount;
uint256 public maxWallet;
bool public limitsInEffect = true;
bool public tradingActive = false;
bool public swapEnabled = false;
uint256 public buyTotalFees;
uint256 public buyLiquidityFee;
uint256 public buyDevFee;
uint256 public sellTotalFees;
uint256 public sellLiquidityFee;
uint256 public sellDevFee;
uint256 public VRFFee;
uint256 public tokensForLiquidity;
uint256 public tokensForDev;
// exlcude from fees and max transaction amount
mapping (address => bool) private _isExcludedFromFees;
mapping (address => bool) public _isExcludedMaxTransactionAmount;
// store addresses that a automatic market maker pairs. Any transfer *to* these addresses
// could be subject to a maximum transfer amount
mapping (address => bool) public automatedMarketMakerPairs;
event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);
event ExcludeFromFees(address indexed account, bool isExcluded);
event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
event devWalletUpdated(address indexed newWallet, address indexed oldWallet);
event SwapAndLiquify(
uint256 tokensSwapped,
uint256 ethReceived,
uint256 tokensIntoLiquidity
);
constructor(uint256 subscriptionId) ERC20("Empire City", "EMPC") VRFConsumerBaseV2Plus(0xD7f86b4b8Cae7D942340FF628F82735b7a20893a) {
s_subscriptionId = subscriptionId;
keyHash = 0x8077df514608a09f83e4e8d300645594e5d7234665448ba83f51a50f842bd3d9;
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x126CFc30e7eb867EE604bBC53Eb95733eF48C55e);
excludeFromMaxTransaction(address(_uniswapV2Router), true);
uniswapV2Router = _uniswapV2Router;
uint256 _buyLiquidityFee = 0;
uint256 _buyDevFee = 3;
uint256 _sellLiquidityFee = 4;
uint256 _sellDevFee = 3;
uint256 _VRFFee = 0.01 ether;
uint256 totalSupply = 1000000 * 1e18;
maxTransactionAmount = totalSupply * 5 / 100; // 5% maxTransactionAmountTxn
maxWallet = totalSupply * 5 / 100; // 5% maxWallet
swapTokensAtAmount = totalSupply * 5 / 10000; // 0.05% swap wallet
buyLiquidityFee = _buyLiquidityFee;
buyDevFee = _buyDevFee;
buyTotalFees = buyLiquidityFee + buyDevFee;
sellLiquidityFee = _sellLiquidityFee;
sellDevFee = _sellDevFee;
sellTotalFees = sellLiquidityFee + sellDevFee;
VRFFee = _VRFFee;
devWallet = address(0x04273222eEb301d665b9E795C02F335f1BcD9dcC); // set as dev wallet
// exclude from paying fees or having max transaction amount
excludeFromFees(owner(), true);
excludeFromFees(address(this), true);
excludeFromFees(address(0xdead), true);
excludeFromMaxTransaction(owner(), true);
excludeFromMaxTransaction(address(this), true);
excludeFromMaxTransaction(address(0xdead), true);
_mint(msg.sender, totalSupply);
}
receive() external payable {}
function flip(uint256 _amount) nonReentrant public payable {
require(_amount <= totalSupply() / 100, "Can not flip more than 1% of the supply at a time");
require(userIdFlip[msg.sender] == 0, "One flip at a time!");
require(msg.value >= VRFFee, "Insufficient VRFFee");
(bool sent, ) = devWallet.call{value: VRFFee}("");
require(sent, "Failed to send VRFFee");
_burn(msg.sender, _amount);
uint256 requestId = s_vrfCoordinator.requestRandomWords(
VRFV2PlusClient.RandomWordsRequest({
keyHash: keyHash,
subId: s_subscriptionId,
requestConfirmations: requestConfirmations,
callbackGasLimit: callbackGasLimit,
numWords: numWords,
extraArgs: VRFV2PlusClient._argsToBytes(
VRFV2PlusClient.ExtraArgsV1({
nativePayment: true
})
)
})
);
requestIdToSender[requestId] = msg.sender;
userIdFlip[msg.sender] = requestId;
betsizeFlip[msg.sender] = (_amount * 199 / 100);
emit betFlip(msg.sender, _amount);
}
function fulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) internal override {
address user = requestIdToSender[requestId];
require(user != address(0), "No game found for the user");
uint256 randomNumber = randomWords[0];
// Flip Game Logic
if (userIdFlip[user] == requestId) {
uint256 secretnum = randomNumber % 2;
if (secretnum == 0){
_mint(user, betsizeFlip[user]);
emit winFlip(user, secretnum, true, betsizeFlip[user]);
}
else {
emit winFlip(user, secretnum, false, betsizeFlip[user]);
}
delete betsizeFlip[user];
delete userIdFlip[user];
}
}
function dangerClearCacheFlip() public {
delete betsizeFlip[msg.sender];
delete userIdFlip[msg.sender];
}
function setRouter(address router) public onlyOwner{
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);
excludeFromMaxTransaction(address(_uniswapV2Router), true);
uniswapV2Router = _uniswapV2Router;
}
// once enabled, can never be turned off
function enableTrading() external onlyOwner {
tradingActive = true;
swapEnabled = true;
}
function removeLimits() external onlyOwner returns (bool){
limitsInEffect = false;
return true;
}
// change the minimum amount of tokens to sell from fees
function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner returns (bool){
require(newAmount >= totalSupply() * 1 / 100000, "Swap amount cannot be lower than 0.001% total supply.");
require(newAmount <= totalSupply() * 1 / 100, "Swap amount cannot be higher than 1% total supply.");
swapTokensAtAmount = newAmount;
return true;
}
function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
require(newNum >= (totalSupply() * 1 / 1000)/1e18, "Cannot set maxTransactionAmount lower than 0.1%");
maxTransactionAmount = newNum * (10**18);
}
function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
require(newNum >= (totalSupply() * 5 / 1000)/1e18, "Cannot set maxWallet lower than 0.5%");
maxWallet = newNum * (10**18);
}
function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
_isExcludedMaxTransactionAmount[updAds] = isEx;
}
// only use to disable contract sales if absolutely necessary (emergency use only)
function updateSwapEnabled(bool enabled) external onlyOwner(){
swapEnabled = enabled;
}
function updateBuyFees(uint256 _liquidityFee, uint256 _devFee) external onlyOwner {
buyLiquidityFee = _liquidityFee;
buyDevFee = _devFee;
buyTotalFees = buyLiquidityFee + buyDevFee;
require(buyTotalFees <= 20, "Must keep fees at 20% or less");
}
function updateSellFees(uint256 _liquidityFee, uint256 _devFee) external onlyOwner {
sellLiquidityFee = _liquidityFee;
sellDevFee = _devFee;
sellTotalFees = sellLiquidityFee + sellDevFee;
require(sellTotalFees <= 25, "Must keep fees at 25% or less");
}
function updateVRFFee(uint256 _newFee) external onlyOwner {
require(_newFee <= 0.1 ether, "Must keep VRF fee <= 0.1 ETH");
VRFFee = _newFee;
}
function excludeFromFees(address account, bool excluded) public onlyOwner {
_isExcludedFromFees[account] = excluded;
emit ExcludeFromFees(account, excluded);
}
function setAutomatedMarketMakerPair(address pair, bool value) public onlyOwner {
_setAutomatedMarketMakerPair(pair, value);
}
function _setAutomatedMarketMakerPair(address pair, bool value) private {
automatedMarketMakerPairs[pair] = value;
emit SetAutomatedMarketMakerPair(pair, value);
}
function updateDevWallet(address newWallet) external onlyOwner {
emit devWalletUpdated(newWallet, devWallet);
devWallet = newWallet;
}
function isExcludedFromFees(address account) public view returns(bool) {
return _isExcludedFromFees[account];
}
function _transfer(
address from,
address to,
uint256 amount
) internal override {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
if(amount == 0) {
super._transfer(from, to, 0);
return;
}
if(limitsInEffect){
if (
from != owner() &&
to != owner() &&
to != address(0) &&
to != address(0xdead) &&
!swapping
){
if(!tradingActive){
require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
}
//when buy
if (automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to]) {
require(amount <= maxTransactionAmount, "Buy transfer amount exceeds the maxTransactionAmount.");
require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
}
//when sell
else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
require(amount <= maxTransactionAmount, "Sell transfer amount exceeds the maxTransactionAmount.");
}
else if(!_isExcludedMaxTransactionAmount[to]){
require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
}
}
}
uint256 contractTokenBalance = balanceOf(address(this));
bool canSwap = contractTokenBalance >= swapTokensAtAmount;
if(
canSwap &&
swapEnabled &&
!swapping &&
!automatedMarketMakerPairs[from] &&
!_isExcludedFromFees[from] &&
!_isExcludedFromFees[to]
) {
swapping = true;
swapBack();
swapping = false;
}
bool takeFee = !swapping;
// if any account belongs to _isExcludedFromFee account then remove the fee
if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
takeFee = false;
}
uint256 fees = 0;
// only take fees on buys/sells, do not take on wallet transfers
if(takeFee){
// on sell
if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
fees = amount * sellTotalFees / 100;
tokensForLiquidity += fees * sellLiquidityFee / sellTotalFees;
tokensForDev += fees * sellDevFee / sellTotalFees;
}
// on buy
else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {
fees = amount * buyTotalFees / 100;
tokensForLiquidity += fees * buyLiquidityFee / buyTotalFees;
tokensForDev += fees * buyDevFee / buyTotalFees;
}
if(fees > 0){
super._transfer(from, address(this), fees);
}
amount -= fees;
}
super._transfer(from, to, amount);
}
function swapTokensForEth(uint256 tokenAmount) private {
// generate the uniswap pair path of token -> WETH
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
// make the swap
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0, // accept any amount of ETH
path,
address(this),
block.timestamp
);
}
function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
// approve token transfer to cover all possible scenarios
_approve(address(this), address(uniswapV2Router), tokenAmount);
// add the liquidity
uniswapV2Router.addLiquidityETH{value: ethAmount}(
address(this),
tokenAmount,
0, // slippage is unavoidable
0, // slippage is unavoidable
devWallet,
block.timestamp
);
}
function swapBack() private {
uint256 contractBalance = balanceOf(address(this));
uint256 totalTokensToSwap = tokensForLiquidity + tokensForDev;
bool success;
if(contractBalance == 0 || totalTokensToSwap == 0) {return;}
if(contractBalance > swapTokensAtAmount * 20){
contractBalance = swapTokensAtAmount * 20;
}
// Halve the amount of liquidity tokens
uint256 liquidityTokens = contractBalance * tokensForLiquidity / totalTokensToSwap / 2;
uint256 amountToSwapForETH = contractBalance - liquidityTokens;
uint256 initialETHBalance = address(this).balance;
swapTokensForEth(amountToSwapForETH);
uint256 ethBalance = address(this).balance - initialETHBalance;
uint256 ethForDev = ethBalance * tokensForDev / totalTokensToSwap;
uint256 ethForLiquidity = ethBalance - ethForDev;
tokensForLiquidity = 0;
tokensForDev = 0;
(success,) = address(devWallet).call{value: ethForDev}("");
if(liquidityTokens > 0 && ethForLiquidity > 0){
addLiquidity(liquidityTokens, ethForLiquidity);
emit SwapAndLiquify(amountToSwapForETH, ethForLiquidity, tokensForLiquidity);
}
(success,) = address(devWallet).call{value: address(this).balance}("");
}
function payout() public onlyOwner {
payable(msg.sender).transfer(address(this).balance);
}
function withdrawToken() public onlyOwner {
this.approve(address(this), totalSupply());
this.transferFrom(address(this), owner(), balanceOf(address(this)));
}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;
// End consumer library.
library VRFV2PlusClient {
// extraArgs will evolve to support new features
bytes4 public constant EXTRA_ARGS_V1_TAG = bytes4(keccak256("VRF ExtraArgsV1"));
struct ExtraArgsV1 {
bool nativePayment;
}
struct RandomWordsRequest {
bytes32 keyHash;
uint256 subId;
uint16 requestConfirmations;
uint32 callbackGasLimit;
uint32 numWords;
bytes extraArgs;
}
function _argsToBytes(ExtraArgsV1 memory extraArgs) internal pure returns (bytes memory bts) {
return abi.encodeWithSelector(EXTRA_ARGS_V1_TAG, extraArgs);
}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;
import {IVRFCoordinatorV2Plus} from "./interfaces/IVRFCoordinatorV2Plus.sol";
import {IVRFMigratableConsumerV2Plus} from "./interfaces/IVRFMigratableConsumerV2Plus.sol";
import {ConfirmedOwner} from "../../shared/access/ConfirmedOwner.sol";
/** ****************************************************************************
* @notice Interface for contracts using VRF randomness
* *****************************************************************************
* @dev PURPOSE
*
* @dev Reggie the Random Oracle (not his real job) wants to provide randomness
* @dev to Vera the verifier in such a way that Vera can be sure he's not
* @dev making his output up to suit himself. Reggie provides Vera a public key
* @dev to which he knows the secret key. Each time Vera provides a seed to
* @dev Reggie, he gives back a value which is computed completely
* @dev deterministically from the seed and the secret key.
*
* @dev Reggie provides a proof by which Vera can verify that the output was
* @dev correctly computed once Reggie tells it to her, but without that proof,
* @dev the output is indistinguishable to her from a uniform random sample
* @dev from the output space.
*
* @dev The purpose of this contract is to make it easy for unrelated contracts
* @dev to talk to Vera the verifier about the work Reggie is doing, to provide
* @dev simple access to a verifiable source of randomness. It ensures 2 things:
* @dev 1. The fulfillment came from the VRFCoordinatorV2Plus.
* @dev 2. The consumer contract implements fulfillRandomWords.
* *****************************************************************************
* @dev USAGE
*
* @dev Calling contracts must inherit from VRFConsumerBaseV2Plus, and can
* @dev initialize VRFConsumerBaseV2Plus's attributes in their constructor as
* @dev shown:
*
* @dev contract VRFConsumerV2Plus is VRFConsumerBaseV2Plus {
* @dev constructor(<other arguments>, address _vrfCoordinator, address _subOwner)
* @dev VRFConsumerBaseV2Plus(_vrfCoordinator, _subOwner) public {
* @dev <initialization with other arguments goes here>
* @dev }
* @dev }
*
* @dev The oracle will have given you an ID for the VRF keypair they have
* @dev committed to (let's call it keyHash). Create a subscription, fund it
* @dev and your consumer contract as a consumer of it (see VRFCoordinatorInterface
* @dev subscription management functions).
* @dev Call requestRandomWords(keyHash, subId, minimumRequestConfirmations,
* @dev callbackGasLimit, numWords, extraArgs),
* @dev see (IVRFCoordinatorV2Plus for a description of the arguments).
*
* @dev Once the VRFCoordinatorV2Plus has received and validated the oracle's response
* @dev to your request, it will call your contract's fulfillRandomWords method.
*
* @dev The randomness argument to fulfillRandomWords is a set of random words
* @dev generated from your requestId and the blockHash of the request.
*
* @dev If your contract could have concurrent requests open, you can use the
* @dev requestId returned from requestRandomWords to track which response is associated
* @dev with which randomness request.
* @dev See "SECURITY CONSIDERATIONS" for principles to keep in mind,
* @dev if your contract could have multiple requests in flight simultaneously.
*
* @dev Colliding `requestId`s are cryptographically impossible as long as seeds
* @dev differ.
*
* *****************************************************************************
* @dev SECURITY CONSIDERATIONS
*
* @dev A method with the ability to call your fulfillRandomness method directly
* @dev could spoof a VRF response with any random value, so it's critical that
* @dev it cannot be directly called by anything other than this base contract
* @dev (specifically, by the VRFConsumerBaseV2Plus.rawFulfillRandomness method).
*
* @dev For your users to trust that your contract's random behavior is free
* @dev from malicious interference, it's best if you can write it so that all
* @dev behaviors implied by a VRF response are executed *during* your
* @dev fulfillRandomness method. If your contract must store the response (or
* @dev anything derived from it) and use it later, you must ensure that any
* @dev user-significant behavior which depends on that stored value cannot be
* @dev manipulated by a subsequent VRF request.
*
* @dev Similarly, both miners and the VRF oracle itself have some influence
* @dev over the order in which VRF responses appear on the blockchain, so if
* @dev your contract could have multiple VRF requests in flight simultaneously,
* @dev you must ensure that the order in which the VRF responses arrive cannot
* @dev be used to manipulate your contract's user-significant behavior.
*
* @dev Since the block hash of the block which contains the requestRandomness
* @dev call is mixed into the input to the VRF *last*, a sufficiently powerful
* @dev miner could, in principle, fork the blockchain to evict the block
* @dev containing the request, forcing the request to be included in a
* @dev different block with a different hash, and therefore a different input
* @dev to the VRF. However, such an attack would incur a substantial economic
* @dev cost. This cost scales with the number of blocks the VRF oracle waits
* @dev until it calls responds to a request. It is for this reason that
* @dev that you can signal to an oracle you'd like them to wait longer before
* @dev responding to the request (however this is not enforced in the contract
* @dev and so remains effective only in the case of unmodified oracle software).
*/
abstract contract VRFConsumerBaseV2Plus is IVRFMigratableConsumerV2Plus, ConfirmedOwner {
error OnlyCoordinatorCanFulfill(address have, address want);
error OnlyOwnerOrCoordinator(address have, address owner, address coordinator);
error ZeroAddress();
// s_vrfCoordinator should be used by consumers to make requests to vrfCoordinator
// so that coordinator reference is updated after migration
IVRFCoordinatorV2Plus public s_vrfCoordinator;
/**
* @param _vrfCoordinator address of VRFCoordinator contract
*/
constructor(address _vrfCoordinator) ConfirmedOwner(msg.sender) {
if (_vrfCoordinator == address(0)) {
revert ZeroAddress();
}
s_vrfCoordinator = IVRFCoordinatorV2Plus(_vrfCoordinator);
}
/**
* @notice fulfillRandomness handles the VRF response. Your contract must
* @notice implement it. See "SECURITY CONSIDERATIONS" above for important
* @notice principles to keep in mind when implementing your fulfillRandomness
* @notice method.
*
* @dev VRFConsumerBaseV2Plus expects its subcontracts to have a method with this
* @dev signature, and will call it once it has verified the proof
* @dev associated with the randomness. (It is triggered via a call to
* @dev rawFulfillRandomness, below.)
*
* @param requestId The Id initially returned by requestRandomness
* @param randomWords the VRF output expanded to the requested number of words
*/
// solhint-disable-next-line chainlink-solidity/prefix-internal-functions-with-underscore
function fulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) internal virtual;
// rawFulfillRandomness is called by VRFCoordinator when it receives a valid VRF
// proof. rawFulfillRandomness then calls fulfillRandomness, after validating
// the origin of the call
function rawFulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) external {
if (msg.sender != address(s_vrfCoordinator)) {
revert OnlyCoordinatorCanFulfill(msg.sender, address(s_vrfCoordinator));
}
fulfillRandomWords(requestId, randomWords);
}
/**
* @inheritdoc IVRFMigratableConsumerV2Plus
*/
function setCoordinator(address _vrfCoordinator) external override onlyOwnerOrCoordinator {
if (_vrfCoordinator == address(0)) {
revert ZeroAddress();
}
s_vrfCoordinator = IVRFCoordinatorV2Plus(_vrfCoordinator);
emit CoordinatorSet(_vrfCoordinator);
}
modifier onlyOwnerOrCoordinator() {
if (msg.sender != owner() && msg.sender != address(s_vrfCoordinator)) {
revert OnlyOwnerOrCoordinator(msg.sender, owner(), address(s_vrfCoordinator));
}
_;
}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import {ConfirmedOwnerWithProposal} from "./ConfirmedOwnerWithProposal.sol";
/// @title The ConfirmedOwner contract
/// @notice A contract with helpers for basic contract ownership.
contract ConfirmedOwner is ConfirmedOwnerWithProposal {
constructor(address newOwner) ConfirmedOwnerWithProposal(newOwner, address(0)) {}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
/// @notice The IVRFMigratableConsumerV2Plus interface defines the
/// @notice method required to be implemented by all V2Plus consumers.
/// @dev This interface is designed to be used in VRFConsumerBaseV2Plus.
interface IVRFMigratableConsumerV2Plus {
event CoordinatorSet(address vrfCoordinator);
/// @notice Sets the VRF Coordinator address
/// @notice This method should only be callable by the coordinator or contract owner
function setCoordinator(address vrfCoordinator) external;
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import {VRFV2PlusClient} from "../libraries/VRFV2PlusClient.sol";
import {IVRFSubscriptionV2Plus} from "./IVRFSubscriptionV2Plus.sol";
// Interface that enables consumers of VRFCoordinatorV2Plus to be future-proof for upgrades
// This interface is supported by subsequent versions of VRFCoordinatorV2Plus
interface IVRFCoordinatorV2Plus is IVRFSubscriptionV2Plus {
/**
* @notice Request a set of random words.
* @param req - a struct containing following fields for randomness request:
* keyHash - Corresponds to a particular oracle job which uses
* that key for generating the VRF proof. Different keyHash's have different gas price
* ceilings, so you can select a specific one to bound your maximum per request cost.
* subId - The ID of the VRF subscription. Must be funded
* with the minimum subscription balance required for the selected keyHash.
* requestConfirmations - How many blocks you'd like the
* oracle to wait before responding to the request. See SECURITY CONSIDERATIONS
* for why you may want to request more. The acceptable range is
* [minimumRequestBlockConfirmations, 200].
* callbackGasLimit - How much gas you'd like to receive in your
* fulfillRandomWords callback. Note that gasleft() inside fulfillRandomWords
* may be slightly less than this amount because of gas used calling the function
* (argument decoding etc.), so you may need to request slightly more than you expect
* to have inside fulfillRandomWords. The acceptable range is
* [0, maxGasLimit]
* numWords - The number of uint256 random values you'd like to receive
* in your fulfillRandomWords callback. Note these numbers are expanded in a
* secure way by the VRFCoordinator from a single random value supplied by the oracle.
* extraArgs - abi-encoded extra args
* @return requestId - A unique identifier of the request. Can be used to match
* a request to a response in fulfillRandomWords.
*/
function requestRandomWords(VRFV2PlusClient.RandomWordsRequest calldata req) external returns (uint256 requestId);
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
/// @notice The IVRFSubscriptionV2Plus interface defines the subscription
/// @notice related methods implemented by the V2Plus coordinator.
interface IVRFSubscriptionV2Plus {
/**
* @notice Add a consumer to a VRF subscription.
* @param subId - ID of the subscription
* @param consumer - New consumer which can use the subscription
*/
function addConsumer(uint256 subId, address consumer) external;
/**
* @notice Remove a consumer from a VRF subscription.
* @param subId - ID of the subscription
* @param consumer - Consumer to remove from the subscription
*/
function removeConsumer(uint256 subId, address consumer) external;
/**
* @notice Cancel a subscription
* @param subId - ID of the subscription
* @param to - Where to send the remaining LINK to
*/
function cancelSubscription(uint256 subId, address to) external;
/**
* @notice Accept subscription owner transfer.
* @param subId - ID of the subscription
* @dev will revert if original owner of subId has
* not requested that msg.sender become the new owner.
*/
function acceptSubscriptionOwnerTransfer(uint256 subId) external;
/**
* @notice Request subscription owner transfer.
* @param subId - ID of the subscription
* @param newOwner - proposed new owner of the subscription
*/
function requestSubscriptionOwnerTransfer(uint256 subId, address newOwner) external;
/**
* @notice Create a VRF subscription.
* @return subId - A unique subscription id.
* @dev You can manage the consumer set dynamically with addConsumer/removeConsumer.
* @dev Note to fund the subscription with LINK, use transferAndCall. For example
* @dev LINKTOKEN.transferAndCall(
* @dev address(COORDINATOR),
* @dev amount,
* @dev abi.encode(subId));
* @dev Note to fund the subscription with Native, use fundSubscriptionWithNative. Be sure
* @dev to send Native with the call, for example:
* @dev COORDINATOR.fundSubscriptionWithNative{value: amount}(subId);
*/
function createSubscription() external returns (uint256 subId);
/**
* @notice Get a VRF subscription.
* @param subId - ID of the subscription
* @return balance - LINK balance of the subscription in juels.
* @return nativeBalance - native balance of the subscription in wei.
* @return reqCount - Requests count of subscription.
* @return owner - owner of the subscription.
* @return consumers - list of consumer address which are able to use this subscription.
*/
function getSubscription(
uint256 subId
)
external
view
returns (uint96 balance, uint96 nativeBalance, uint64 reqCount, address owner, address[] memory consumers);
/*
* @notice Check to see if there exists a request commitment consumers
* for all consumers and keyhashes for a given sub.
* @param subId - ID of the subscription
* @return true if there exists at least one unfulfilled request for the subscription, false
* otherwise.
*/
function pendingRequestExists(uint256 subId) external view returns (bool);
/**
* @notice Paginate through all active VRF subscriptions.
* @param startIndex index of the subscription to start from
* @param maxCount maximum number of subscriptions to return, 0 to return all
* @dev the order of IDs in the list is **not guaranteed**, therefore, if making successive calls, one
* @dev should consider keeping the blockheight constant to ensure a holistic picture of the contract state
*/
function getActiveSubscriptionIds(uint256 startIndex, uint256 maxCount) external view returns (uint256[] memory);
/**
* @notice Fund a subscription with native.
* @param subId - ID of the subscription
* @notice This method expects msg.value to be greater than or equal to 0.
*/
function fundSubscriptionWithNative(uint256 subId) external payable;
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import {IOwnable} from "../interfaces/IOwnable.sol";
/// @title The ConfirmedOwner contract
/// @notice A contract with helpers for basic contract ownership.
contract ConfirmedOwnerWithProposal is IOwnable {
address private s_owner;
address private s_pendingOwner;
event OwnershipTransferRequested(address indexed from, address indexed to);
event OwnershipTransferred(address indexed from, address indexed to);
constructor(address newOwner, address pendingOwner) {
// solhint-disable-next-line gas-custom-errors
require(newOwner != address(0), "Cannot set owner to zero");
s_owner = newOwner;
if (pendingOwner != address(0)) {
_transferOwnership(pendingOwner);
}
}
/// @notice Allows an owner to begin transferring ownership to a new address.
function transferOwnership(address to) public override onlyOwner {
_transferOwnership(to);
}
/// @notice Allows an ownership transfer to be completed by the recipient.
function acceptOwnership() external override {
// solhint-disable-next-line gas-custom-errors
require(msg.sender == s_pendingOwner, "Must be proposed owner");
address oldOwner = s_owner;
s_owner = msg.sender;
s_pendingOwner = address(0);
emit OwnershipTransferred(oldOwner, msg.sender);
}
/// @notice Get the current owner
function owner() public view override returns (address) {
return s_owner;
}
/// @notice validate, transfer ownership, and emit relevant events
function _transferOwnership(address to) private {
// solhint-disable-next-line gas-custom-errors
require(to != msg.sender, "Cannot transfer to self");
s_pendingOwner = to;
emit OwnershipTransferRequested(s_owner, to);
}
/// @notice validate access
function _validateOwnership() internal view {
// solhint-disable-next-line gas-custom-errors
require(msg.sender == s_owner, "Only callable by owner");
}
/// @notice Reverts if called by anyone other than the contract owner.
modifier onlyOwner() {
_validateOwnership();
_;
}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
interface IOwnable {
function owner() external returns (address);
function transferOwnership(address recipient) external;
function acceptOwnership() external;
}{
"optimizer": {
"enabled": true,
"runs": 200
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
}
}Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"uint256","name":"subscriptionId","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"have","type":"address"},{"internalType":"address","name":"want","type":"address"}],"name":"OnlyCoordinatorCanFulfill","type":"error"},{"inputs":[{"internalType":"address","name":"have","type":"address"},{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"coordinator","type":"address"}],"name":"OnlyOwnerOrCoordinator","type":"error"},{"inputs":[],"name":"Reentrancy","type":"error"},{"inputs":[],"name":"ZeroAddress","type":"error"},{"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":false,"internalType":"address","name":"vrfCoordinator","type":"address"}],"name":"CoordinatorSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"OwnershipTransferRequested","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","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"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"betFlip","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"devWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"roll","type":"uint256"},{"indexed":false,"internalType":"bool","name":"won","type":"bool"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"winFlip","type":"event"},{"inputs":[],"name":"VRFFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"acceptOwnership","outputs":[],"stateMutability":"nonpayable","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":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"betsizeFlip","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dangerClearCacheFlip","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"devWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"flip","outputs":[],"stateMutability":"payable","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":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","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":"payout","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"requestId","type":"uint256"},{"internalType":"uint256[]","name":"randomWords","type":"uint256[]"}],"name":"rawFulfillRandomWords","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"s_vrfCoordinator","outputs":[{"internalType":"contract IVRFCoordinatorV2Plus","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_vrfCoordinator","type":"address"}],"name":"setCoordinator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"router","type":"address"}],"name":"setRouter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForDev","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updateDevWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateMaxTxnAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateMaxWalletAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newFee","type":"uint256"}],"name":"updateVRFFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"userIdFlip","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]Contract Creation Code
608060405260016005819055600b80546001600160501b03191666010003002625a01790556014805462ffffff191690911790553480156200003f575f80fd5b50604051620037193803806200371983398101604081905262000062916200060d565b73d7f86b4b8cae7d942340ff628f82735b7a20893a33805f6040518060400160405280600b81526020016a456d70697265204369747960a81b81525060405180604001604052806004815260200163454d504360e01b8152508160039081620000cc9190620006c4565b506004620000db8282620006c4565b5050506001600160a01b0382166200013a5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420736574206f776e657220746f207a65726f000000000000000060448201526064015b60405180910390fd5b600680546001600160a01b0319166001600160a01b03848116919091179091558116156200016d576200016d816200037f565b5050506001600160a01b038116620001985760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b039290921691909117905560098190557f8077df514608a09f83e4e8d300645594e5d7234665448ba83f51a50f842bd3d9600a5573126cfc30e7eb867ee604bbc53eb95733ef48c55e620002038160016200042a565b600f80546001600160a01b0319166001600160a01b0383161790555f6003600481662386f26fc1000069d3c21bcecceda1000000606462000246826005620007a0565b620002529190620007c0565b601155606462000264826005620007a0565b620002709190620007c0565b60135561271062000283826005620007a0565b6200028f9190620007c0565b60125560168690556017859055620002a88587620007e0565b6015556019849055601a839055620002c18385620007e0565b601855601b829055601080546001600160a01b0319167304273222eeb301d665b9e795c02f335f1bcd9dcc1790556200030e620003066006546001600160a01b031690565b60016200045e565b6200031b3060016200045e565b6200032a61dead60016200045e565b62000349620003416006546001600160a01b031690565b60016200042a565b620003563060016200042a565b6200036561dead60016200042a565b620003713382620004c6565b5050505050505050620007f6565b336001600160a01b03821603620003d95760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c66000000000000000000604482015260640162000131565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b62000434620005aa565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b62000468620005aa565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200051e5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640162000131565b806002546200052e9190620007e0565b6002556001600160a01b0382165f9081526020819052604090205462000556908290620007e0565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6006546001600160a01b03163314620006065760405162461bcd60e51b815260206004820152601660248201527f4f6e6c792063616c6c61626c65206279206f776e657200000000000000000000604482015260640162000131565b565b505050565b5f602082840312156200061e575f80fd5b5051919050565b634e487b7160e01b5f52604160045260245ffd5b600181811c908216806200064e57607f821691505b6020821081036200066d57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000608575f81815260208120601f850160051c810160208610156200069b5750805b601f850160051c820191505b81811015620006bc57828155600101620006a7565b505050505050565b81516001600160401b03811115620006e057620006e062000625565b620006f881620006f1845462000639565b8462000673565b602080601f8311600181146200072e575f8415620007165750858301515b5f19600386901b1c1916600185901b178555620006bc565b5f85815260208120601f198616915b828110156200075e578886015182559484019460019091019084016200073d565b50858210156200077c57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b8082028115828204841417620007ba57620007ba6200078c565b92915050565b5f82620007db57634e487b7160e01b5f52601260045260245ffd5b500490565b80820180821115620007ba57620007ba6200078c565b612f1580620008045f395ff3fe608060405260043610610374575f3560e01c80638da5cb5b116101c8578063b62496f5116100fd578063d257b34f1161009d578063f11a24d31161006d578063f11a24d314610a13578063f2fde38b14610a28578063f637434214610a47578063f8b45b0514610a5c575f80fd5b8063d257b34f14610986578063d85ba063146109a5578063dd62ed3e146109ba578063e2f45605146109fe575f80fd5b8063c0d78655116100d8578063c0d786551461091f578063c18bc1951461093e578063c8c8ebe41461095d578063ca628c7814610972575f80fd5b8063b62496f5146108b5578063bbc0c742146108e2578063c024666814610900575f80fd5b80639c3b4fdc11610168578063a0d82dc511610143578063a0d82dc514610837578063a457c2d71461084c578063a6b5717c1461086b578063a9059cbb14610896575f80fd5b80639c3b4fdc146107ee5780639eccacf6146108035780639fccce3214610822575f80fd5b8063924de9b7116101a3578063924de9b714610787578063935cbe15146107a657806395d89b41146107bb5780639a7a23d6146107cf575f80fd5b80638da5cb5b1461072c5780638ea5220f146107495780638ea9811714610768575f80fd5b80632aec3ab9116102a957806366ca9b8311610249578063751039fc11610219578063751039fc146106d15780637571336a146106e557806379ba5097146107045780638a8c523c14610718575f80fd5b806366ca9b831461064a5780636a486a8e146106695780636ddd17131461067e57806370a082311461069d575f80fd5b80634a62bb65116102845780634a62bb65146105bb5780634fbee193146105d45780635fb7a3021461060b57806363bd1d4a14610636575f80fd5b80632aec3ab914610562578063313ce56714610581578063395093511461059c575f80fd5b80631816467f11610314578063203e727e116102ef578063203e727e146104fc578063221e885d1461051b57806323b872dd1461052e57806327c8f8351461054d575f80fd5b80631816467f146104a95780631a8145bb146104c85780631fe543e3146104dd575f80fd5b806310d5de531161034f57806310d5de53146103f95780631694505e1461042757806316fd63021461045e57806318160ddd1461048b575f80fd5b806302dbd8f81461037f57806306fdde03146103a0578063095ea7b3146103ca575f80fd5b3661037b57005b5f80fd5b34801561038a575f80fd5b5061039e610399366004612a08565b610a71565b005b3480156103ab575f80fd5b506103b4610aeb565b6040516103c19190612a6b565b60405180910390f35b3480156103d5575f80fd5b506103e96103e4366004612a98565b610b7b565b60405190151581526020016103c1565b348015610404575f80fd5b506103e9610413366004612ac2565b601f6020525f908152604090205460ff1681565b348015610432575f80fd5b50600f54610446906001600160a01b031681565b6040516001600160a01b0390911681526020016103c1565b348015610469575f80fd5b5061039e335f908152600e60209081526040808320839055600d909152812055565b348015610496575f80fd5b506002545b6040519081526020016103c1565b3480156104b4575f80fd5b5061039e6104c3366004612ac2565b610b91565b3480156104d3575f80fd5b5061049b601c5481565b3480156104e8575f80fd5b5061039e6104f7366004612add565b610bf5565b348015610507575f80fd5b5061039e610516366004612b55565b610c45565b61039e610529366004612b55565b610d00565b348015610539575f80fd5b506103e9610548366004612b6c565b61105e565b348015610558575f80fd5b5061044661dead81565b34801561056d575f80fd5b5061039e61057c366004612b55565b6110ae565b34801561058c575f80fd5b50604051601281526020016103c1565b3480156105a7575f80fd5b506103e96105b6366004612a98565b611113565b3480156105c6575f80fd5b506014546103e99060ff1681565b3480156105df575f80fd5b506103e96105ee366004612ac2565b6001600160a01b03165f908152601e602052604090205460ff1690565b348015610616575f80fd5b5061049b610625366004612ac2565b600e6020525f908152604090205481565b348015610641575f80fd5b5061039e611149565b348015610655575f80fd5b5061039e610664366004612a08565b61117d565b348015610674575f80fd5b5061049b60185481565b348015610689575f80fd5b506014546103e99062010000900460ff1681565b3480156106a8575f80fd5b5061049b6106b7366004612ac2565b6001600160a01b03165f9081526020819052604090205490565b3480156106dc575f80fd5b506103e96111ee565b3480156106f0575f80fd5b5061039e6106ff366004612bb7565b611207565b34801561070f575f80fd5b5061039e611239565b348015610723575f80fd5b5061039e6112e6565b348015610737575f80fd5b506006546001600160a01b0316610446565b348015610754575f80fd5b50601054610446906001600160a01b031681565b348015610773575f80fd5b5061039e610782366004612ac2565b611301565b348015610792575f80fd5b5061039e6107a1366004612bee565b6113f3565b3480156107b1575f80fd5b5061049b601b5481565b3480156107c6575f80fd5b506103b4611417565b3480156107da575f80fd5b5061039e6107e9366004612bb7565b611426565b3480156107f9575f80fd5b5061049b60175481565b34801561080e575f80fd5b50600854610446906001600160a01b031681565b34801561082d575f80fd5b5061049b601d5481565b348015610842575f80fd5b5061049b601a5481565b348015610857575f80fd5b506103e9610866366004612a98565b611438565b348015610876575f80fd5b5061049b610885366004612ac2565b600d6020525f908152604090205481565b3480156108a1575f80fd5b506103e96108b0366004612a98565b61146e565b3480156108c0575f80fd5b506103e96108cf366004612ac2565b602080525f908152604090205460ff1681565b3480156108ed575f80fd5b506014546103e990610100900460ff1681565b34801561090b575f80fd5b5061039e61091a366004612bb7565b61147a565b34801561092a575f80fd5b5061039e610939366004612ac2565b6114e0565b348015610949575f80fd5b5061039e610958366004612b55565b611517565b348015610968575f80fd5b5061049b60115481565b34801561097d575f80fd5b5061039e6115c6565b348015610991575f80fd5b506103e96109a0366004612b55565b6116e8565b3480156109b0575f80fd5b5061049b60155481565b3480156109c5575f80fd5b5061049b6109d4366004612c09565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610a09575f80fd5b5061049b60125481565b348015610a1e575f80fd5b5061049b60165481565b348015610a33575f80fd5b5061039e610a42366004612ac2565b611813565b348015610a52575f80fd5b5061049b60195481565b348015610a67575f80fd5b5061049b60135481565b610a79611824565b6019829055601a819055610a8d8183612c49565b601881905560191015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323525206f72206c65737300000060448201526064015b60405180910390fd5b5050565b606060038054610afa90612c5c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b2690612c5c565b8015610b715780601f10610b4857610100808354040283529160200191610b71565b820191905f5260205f20905b815481529060010190602001808311610b5457829003601f168201915b5050505050905090565b5f610b87338484611879565b5060015b92915050565b610b99611824565b6010546040516001600160a01b03918216918316907f90b8024c4923d3873ff5b9fcb43d0360d4b9217fa41225d07ba379993552e743905f90a3601080546001600160a01b0319166001600160a01b0392909216919091179055565b6008546001600160a01b03163314610c355760085460405163073e64fd60e21b81523360048201526001600160a01b039091166024820152604401610ade565b610c4083838361199d565b505050565b610c4d611824565b670de0b6b3a76400006103e8610c6260025490565b610c6d906001612c94565b610c779190612cbf565b610c819190612cbf565b811015610ce85760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e312560881b6064820152608401610ade565b610cfa81670de0b6b3a7640000612c94565b60115550565b600554600114610d235760405163558a1e0360e11b815260040160405180910390fd5b60026005556064610d3360025490565b610d3d9190612cbf565b811115610da65760405162461bcd60e51b815260206004820152603160248201527f43616e206e6f7420666c6970206d6f7265207468616e203125206f662074686560448201527020737570706c7920617420612074696d6560781b6064820152608401610ade565b335f908152600d602052604090205415610df85760405162461bcd60e51b81526020600482015260136024820152724f6e6520666c697020617420612074696d652160681b6044820152606401610ade565b601b54341015610e405760405162461bcd60e51b8152602060048201526013602482015272496e73756666696369656e742056524646656560681b6044820152606401610ade565b601054601b546040515f926001600160a01b031691908381818185875af1925050503d805f8114610e8c576040519150601f19603f3d011682016040523d82523d5f602084013e610e91565b606091505b5050905080610eda5760405162461bcd60e51b81526020600482015260156024820152744661696c656420746f2073656e642056524646656560581b6044820152606401610ade565b610ee43383611b77565b6008546040805160c081018252600a548152600954602080830191909152600b5461ffff6401000000008204168385015263ffffffff808216606085015266010000000000009091041660808301528251908101909252600182525f926001600160a01b031691639b1c385e919060a0820190610f6090611c68565b8152506040518263ffffffff1660e01b8152600401610f7f9190612cd2565b6020604051808303815f875af1158015610f9b573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fbf9190612d36565b5f818152600c6020908152604080832080546001600160a01b031916339081179091558352600d909152902081905590506064610ffd8460c7612c94565b6110079190612cbf565b335f818152600e6020526040908190209290925590517feb60f01d57d2fe4e66ef31e4b2166288174d4cf64772f0a4e59d66e6a4a832589061104c9086815260200190565b60405180910390a25050600160055550565b5f61106a848484611cd9565b6001600160a01b0384165f908152600160209081526040808320338085529252909120546110a491869161109f908690612d4d565b611879565b5060019392505050565b6110b6611824565b67016345785d8a000081111561110e5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702056524620666565203c3d20302e3120455448000000006044820152606401610ade565b601b55565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612c49565b611151611824565b60405133904780156108fc02915f818181858888f1935050505015801561117a573d5f803e3d5ffd5b50565b611185611824565b601682905560178190556111998183612c49565b601581905560141015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c6573730000006044820152606401610ade565b5f6111f7611824565b506014805460ff19169055600190565b61120f611824565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b6007546001600160a01b0316331461128c5760405162461bcd60e51b815260206004820152601660248201527526bab9ba10313290383937b837b9b2b21037bbb732b960511b6044820152606401610ade565b600680546001600160a01b0319808216339081179093556007805490911690556040516001600160a01b03909116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b6112ee611824565b6014805462ffff00191662010100179055565b6006546001600160a01b0316331480159061132757506008546001600160a01b03163314155b15611378573361133f6006546001600160a01b031690565b60085460405163061db9c160e01b81526001600160a01b0393841660048201529183166024830152919091166044820152606401610ade565b6001600160a01b03811661139f5760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b0383169081179091556040519081527fd1a6a14209a385a964d036e404cb5cfb71f4000cdb03c9366292430787261be69060200160405180910390a150565b6113fb611824565b60148054911515620100000262ff000019909216919091179055565b606060048054610afa90612c5c565b61142e611824565b610ae7828261235e565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612d4d565b5f610b87338484611cd9565b611482611824565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6114e8611824565b806114f4816001611207565b600f80546001600160a01b0319166001600160a01b039290921691909117905550565b61151f611824565b670de0b6b3a76400006103e861153460025490565b61153f906005612c94565b6115499190612cbf565b6115539190612cbf565b8110156115ae5760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263302e352560e01b6064820152608401610ade565b6115c081670de0b6b3a7640000612c94565b60135550565b6115ce611824565b3063095ea7b3816115de60025490565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af1158015611626573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061164a9190612d60565b50306323b872dd816116646006546001600160a01b031690565b305f908152602081905260409020546040516001600160e01b031960e086901b1681526001600160a01b03938416600482015292909116602483015260448201526064016020604051808303815f875af11580156116c4573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a9190612d60565b5f6116f1611824565b620186a06116fe60025490565b611709906001612c94565b6117139190612cbf565b8210156117805760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ade565b606461178b60025490565b611796906001612c94565b6117a09190612cbf565b82111561180a5760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ade565b50601255600190565b61181b611824565b61117a816123b0565b6006546001600160a01b031633146118775760405162461bcd60e51b815260206004820152601660248201527527b7363c9031b0b63630b1363290313c9037bbb732b960511b6044820152606401610ade565b565b6001600160a01b0383166118db5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ade565b6001600160a01b03821661193c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ade565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b5f838152600c60205260409020546001600160a01b031680611a015760405162461bcd60e51b815260206004820152601a60248201527f4e6f2067616d6520666f756e6420666f722074686520757365720000000000006044820152606401610ade565b5f83835f818110611a1457611a14612d7b565b90506020020135905084600d5f846001600160a01b03166001600160a01b031681526020019081526020015f205403611b70575f611a53600283612d8f565b9050805f03611ae9576001600160a01b0383165f908152600e6020526040902054611a7f908490612459565b6001600160a01b0383165f818152600e6020526040908190205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad991611adc9185916001919283529015156020830152604082015260600190565b60405180910390a2611b49565b6001600160a01b0383165f818152600e60205260408082205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad992611b40928683529015156020830152604082015260600190565b60405180910390a25b506001600160a01b0382165f908152600e60209081526040808320839055600d9091528120555b5050505050565b6001600160a01b038216611bd75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610ade565b6001600160a01b0382165f90815260208190526040902054611bfa908290612d4d565b6001600160a01b0383165f90815260208190526040902055600254611c20908290612d4d565b6002556040518181525f906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020015b60405180910390a35050565b60607f92fd13387c7fe7befbc38d303d6468778fb9731bc4583f17d92989c6fcfdeaaa82604051602401611ca191511515815260200190565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b03199093169290921790915292915050565b6001600160a01b038316611cff5760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b038216611d255760405162461bcd60e51b8152600401610ade90612de7565b805f03611d3757610c4083835f612530565b60145460ff16156120a2576006546001600160a01b03848116911614801590611d6e57506006546001600160a01b03838116911614155b8015611d8257506001600160a01b03821615155b8015611d9957506001600160a01b03821661dead14155b8015611daf5750600f54600160a01b900460ff16155b156120a257601454610100900460ff16611e45576001600160a01b0383165f908152601e602052604090205460ff1680611e0057506001600160a01b0382165f908152601e602052604090205460ff165b611e455760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610ade565b6001600160a01b0383165f90815260208052604090205460ff168015611e8357506001600160a01b0382165f908152601f602052604090205460ff16155b15611f6657601154811115611ef85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ade565b6013546001600160a01b0383165f90815260208190526040902054611f1d9083612c49565b1115611f615760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b6120a2565b6001600160a01b0382165f90815260208052604090205460ff168015611fa457506001600160a01b0383165f908152601f602052604090205460ff16155b1561201a57601154811115611f615760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ade565b6001600160a01b0382165f908152601f602052604090205460ff166120a2576013546001600160a01b0383165f9081526020819052604090205461205e9083612c49565b11156120a25760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b305f90815260208190526040902054601254811080159081906120cd575060145462010000900460ff165b80156120e35750600f54600160a01b900460ff16155b801561210657506001600160a01b0385165f90815260208052604090205460ff16155b801561212a57506001600160a01b0385165f908152601e602052604090205460ff16155b801561214e57506001600160a01b0384165f908152601e602052604090205460ff16155b1561217c57600f805460ff60a01b1916600160a01b17905561216e61261e565b600f805460ff60a01b191690555b600f546001600160a01b0386165f908152601e602052604090205460ff600160a01b9092048216159116806121c857506001600160a01b0385165f908152601e602052604090205460ff165b156121d057505f5b5f811561234a576001600160a01b0386165f90815260208052604090205460ff1680156121fe57505f601854115b15612284576064601854866122139190612c94565b61221d9190612cbf565b9050601854601954826122309190612c94565b61223a9190612cbf565b601c5f82825461224a9190612c49565b9091555050601854601a5461225f9083612c94565b6122699190612cbf565b601d5f8282546122799190612c49565b9091555061232c9050565b6001600160a01b0387165f90815260208052604090205460ff1680156122ab57505f601554115b1561232c576064601554866122c09190612c94565b6122ca9190612cbf565b9050601554601654826122dd9190612c94565b6122e79190612cbf565b601c5f8282546122f79190612c49565b909155505060155460175461230c9083612c94565b6123169190612cbf565b601d5f8282546123269190612c49565b90915550505b801561233d5761233d873083612530565b6123478186612d4d565b94505b612355878787612530565b50505050505050565b6001600160a01b0382165f818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b336001600160a01b038216036124085760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c660000000000000000006044820152606401610ade565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b6001600160a01b0382166124af5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610ade565b806002546124bd9190612c49565b6002556001600160a01b0382165f908152602081905260409020546124e3908290612c49565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611c5c565b6001600160a01b0383166125565760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b03821661257c5760405162461bcd60e51b8152600401610ade90612de7565b6001600160a01b0383165f9081526020819052604090205461259f908290612d4d565b6001600160a01b038085165f9081526020819052604080822093909355908416815220546125ce908290612c49565b6001600160a01b038381165f818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611990565b305f9081526020819052604081205490505f601d54601c546126409190612c49565b90505f82158061264e575081155b1561265857505050565b601254612666906014612c94565b83111561267e5760125461267b906014612c94565b92505b5f600283601c54866126909190612c94565b61269a9190612cbf565b6126a49190612cbf565b90505f6126b18286612d4d565b9050476126bd8261280e565b5f6126c88247612d4d565b90505f86601d54836126da9190612c94565b6126e49190612cbf565b90505f6126f18284612d4d565b5f601c819055601d8190556010546040519293506001600160a01b031691849181818185875af1925050503d805f8114612746576040519150601f19603f3d011682016040523d82523d5f602084013e61274b565b606091505b5090975050851580159061275e57505f81115b156127b15761276d868261295e565b601c54604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6010546040516001600160a01b039091169047905f81818185875af1925050503d805f81146127fb576040519150601f19603f3d011682016040523d82523d5f602084013e612800565b606091505b505050505050505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061284157612841612d7b565b6001600160a01b03928316602091820292909201810191909152600f54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612898573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906128bc9190612e2a565b816001815181106128cf576128cf612d7b565b6001600160a01b039283166020918202929092010152600f546128f59130911684611879565b600f5460405163791ac94760e01b81526001600160a01b039091169063791ac9479061292d9085905f90869030904290600401612e45565b5f604051808303815f87803b158015612944575f80fd5b505af1158015612956573d5f803e3d5ffd5b505050505050565b600f546129769030906001600160a01b031684611879565b600f5460105460405163f305d71960e01b8152306004820152602481018590525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af11580156129e3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611b709190612eb4565b5f8060408385031215612a19575f80fd5b50508035926020909101359150565b5f81518084525f5b81811015612a4c57602081850181015186830182015201612a30565b505f602082860101526020601f19601f83011685010191505092915050565b602081525f612a7d6020830184612a28565b9392505050565b6001600160a01b038116811461117a575f80fd5b5f8060408385031215612aa9575f80fd5b8235612ab481612a84565b946020939093013593505050565b5f60208284031215612ad2575f80fd5b8135612a7d81612a84565b5f805f60408486031215612aef575f80fd5b83359250602084013567ffffffffffffffff80821115612b0d575f80fd5b818601915086601f830112612b20575f80fd5b813581811115612b2e575f80fd5b8760208260051b8501011115612b42575f80fd5b6020830194508093505050509250925092565b5f60208284031215612b65575f80fd5b5035919050565b5f805f60608486031215612b7e575f80fd5b8335612b8981612a84565b92506020840135612b9981612a84565b929592945050506040919091013590565b801515811461117a575f80fd5b5f8060408385031215612bc8575f80fd5b8235612bd381612a84565b91506020830135612be381612baa565b809150509250929050565b5f60208284031215612bfe575f80fd5b8135612a7d81612baa565b5f8060408385031215612c1a575f80fd5b8235612c2581612a84565b91506020830135612be381612a84565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b8b57610b8b612c35565b600181811c90821680612c7057607f821691505b602082108103612c8e57634e487b7160e01b5f52602260045260245ffd5b50919050565b8082028115828204841417610b8b57610b8b612c35565b634e487b7160e01b5f52601260045260245ffd5b5f82612ccd57612ccd612cab565b500490565b60208152815160208201526020820151604082015261ffff60408301511660608201525f606083015163ffffffff80821660808501528060808601511660a0850152505060a083015160c080840152612d2e60e0840182612a28565b949350505050565b5f60208284031215612d46575f80fd5b5051919050565b81810381811115610b8b57610b8b612c35565b5f60208284031215612d70575f80fd5b8151612a7d81612baa565b634e487b7160e01b5f52603260045260245ffd5b5f82612d9d57612d9d612cab565b500690565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b5f60208284031215612e3a575f80fd5b8151612a7d81612a84565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015612e935784516001600160a01b031683529383019391830191600101612e6e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215612ec6575f80fd5b835192506020840151915060408401519050925092509256fea264697066735822122014be96ed9d9fb8d1b8c3c6e9e26a76af88c3b76cdba8357b467974145befaba764736f6c63430008140033940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71
Deployed Bytecode
0x608060405260043610610374575f3560e01c80638da5cb5b116101c8578063b62496f5116100fd578063d257b34f1161009d578063f11a24d31161006d578063f11a24d314610a13578063f2fde38b14610a28578063f637434214610a47578063f8b45b0514610a5c575f80fd5b8063d257b34f14610986578063d85ba063146109a5578063dd62ed3e146109ba578063e2f45605146109fe575f80fd5b8063c0d78655116100d8578063c0d786551461091f578063c18bc1951461093e578063c8c8ebe41461095d578063ca628c7814610972575f80fd5b8063b62496f5146108b5578063bbc0c742146108e2578063c024666814610900575f80fd5b80639c3b4fdc11610168578063a0d82dc511610143578063a0d82dc514610837578063a457c2d71461084c578063a6b5717c1461086b578063a9059cbb14610896575f80fd5b80639c3b4fdc146107ee5780639eccacf6146108035780639fccce3214610822575f80fd5b8063924de9b7116101a3578063924de9b714610787578063935cbe15146107a657806395d89b41146107bb5780639a7a23d6146107cf575f80fd5b80638da5cb5b1461072c5780638ea5220f146107495780638ea9811714610768575f80fd5b80632aec3ab9116102a957806366ca9b8311610249578063751039fc11610219578063751039fc146106d15780637571336a146106e557806379ba5097146107045780638a8c523c14610718575f80fd5b806366ca9b831461064a5780636a486a8e146106695780636ddd17131461067e57806370a082311461069d575f80fd5b80634a62bb65116102845780634a62bb65146105bb5780634fbee193146105d45780635fb7a3021461060b57806363bd1d4a14610636575f80fd5b80632aec3ab914610562578063313ce56714610581578063395093511461059c575f80fd5b80631816467f11610314578063203e727e116102ef578063203e727e146104fc578063221e885d1461051b57806323b872dd1461052e57806327c8f8351461054d575f80fd5b80631816467f146104a95780631a8145bb146104c85780631fe543e3146104dd575f80fd5b806310d5de531161034f57806310d5de53146103f95780631694505e1461042757806316fd63021461045e57806318160ddd1461048b575f80fd5b806302dbd8f81461037f57806306fdde03146103a0578063095ea7b3146103ca575f80fd5b3661037b57005b5f80fd5b34801561038a575f80fd5b5061039e610399366004612a08565b610a71565b005b3480156103ab575f80fd5b506103b4610aeb565b6040516103c19190612a6b565b60405180910390f35b3480156103d5575f80fd5b506103e96103e4366004612a98565b610b7b565b60405190151581526020016103c1565b348015610404575f80fd5b506103e9610413366004612ac2565b601f6020525f908152604090205460ff1681565b348015610432575f80fd5b50600f54610446906001600160a01b031681565b6040516001600160a01b0390911681526020016103c1565b348015610469575f80fd5b5061039e335f908152600e60209081526040808320839055600d909152812055565b348015610496575f80fd5b506002545b6040519081526020016103c1565b3480156104b4575f80fd5b5061039e6104c3366004612ac2565b610b91565b3480156104d3575f80fd5b5061049b601c5481565b3480156104e8575f80fd5b5061039e6104f7366004612add565b610bf5565b348015610507575f80fd5b5061039e610516366004612b55565b610c45565b61039e610529366004612b55565b610d00565b348015610539575f80fd5b506103e9610548366004612b6c565b61105e565b348015610558575f80fd5b5061044661dead81565b34801561056d575f80fd5b5061039e61057c366004612b55565b6110ae565b34801561058c575f80fd5b50604051601281526020016103c1565b3480156105a7575f80fd5b506103e96105b6366004612a98565b611113565b3480156105c6575f80fd5b506014546103e99060ff1681565b3480156105df575f80fd5b506103e96105ee366004612ac2565b6001600160a01b03165f908152601e602052604090205460ff1690565b348015610616575f80fd5b5061049b610625366004612ac2565b600e6020525f908152604090205481565b348015610641575f80fd5b5061039e611149565b348015610655575f80fd5b5061039e610664366004612a08565b61117d565b348015610674575f80fd5b5061049b60185481565b348015610689575f80fd5b506014546103e99062010000900460ff1681565b3480156106a8575f80fd5b5061049b6106b7366004612ac2565b6001600160a01b03165f9081526020819052604090205490565b3480156106dc575f80fd5b506103e96111ee565b3480156106f0575f80fd5b5061039e6106ff366004612bb7565b611207565b34801561070f575f80fd5b5061039e611239565b348015610723575f80fd5b5061039e6112e6565b348015610737575f80fd5b506006546001600160a01b0316610446565b348015610754575f80fd5b50601054610446906001600160a01b031681565b348015610773575f80fd5b5061039e610782366004612ac2565b611301565b348015610792575f80fd5b5061039e6107a1366004612bee565b6113f3565b3480156107b1575f80fd5b5061049b601b5481565b3480156107c6575f80fd5b506103b4611417565b3480156107da575f80fd5b5061039e6107e9366004612bb7565b611426565b3480156107f9575f80fd5b5061049b60175481565b34801561080e575f80fd5b50600854610446906001600160a01b031681565b34801561082d575f80fd5b5061049b601d5481565b348015610842575f80fd5b5061049b601a5481565b348015610857575f80fd5b506103e9610866366004612a98565b611438565b348015610876575f80fd5b5061049b610885366004612ac2565b600d6020525f908152604090205481565b3480156108a1575f80fd5b506103e96108b0366004612a98565b61146e565b3480156108c0575f80fd5b506103e96108cf366004612ac2565b602080525f908152604090205460ff1681565b3480156108ed575f80fd5b506014546103e990610100900460ff1681565b34801561090b575f80fd5b5061039e61091a366004612bb7565b61147a565b34801561092a575f80fd5b5061039e610939366004612ac2565b6114e0565b348015610949575f80fd5b5061039e610958366004612b55565b611517565b348015610968575f80fd5b5061049b60115481565b34801561097d575f80fd5b5061039e6115c6565b348015610991575f80fd5b506103e96109a0366004612b55565b6116e8565b3480156109b0575f80fd5b5061049b60155481565b3480156109c5575f80fd5b5061049b6109d4366004612c09565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610a09575f80fd5b5061049b60125481565b348015610a1e575f80fd5b5061049b60165481565b348015610a33575f80fd5b5061039e610a42366004612ac2565b611813565b348015610a52575f80fd5b5061049b60195481565b348015610a67575f80fd5b5061049b60135481565b610a79611824565b6019829055601a819055610a8d8183612c49565b601881905560191015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323525206f72206c65737300000060448201526064015b60405180910390fd5b5050565b606060038054610afa90612c5c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b2690612c5c565b8015610b715780601f10610b4857610100808354040283529160200191610b71565b820191905f5260205f20905b815481529060010190602001808311610b5457829003601f168201915b5050505050905090565b5f610b87338484611879565b5060015b92915050565b610b99611824565b6010546040516001600160a01b03918216918316907f90b8024c4923d3873ff5b9fcb43d0360d4b9217fa41225d07ba379993552e743905f90a3601080546001600160a01b0319166001600160a01b0392909216919091179055565b6008546001600160a01b03163314610c355760085460405163073e64fd60e21b81523360048201526001600160a01b039091166024820152604401610ade565b610c4083838361199d565b505050565b610c4d611824565b670de0b6b3a76400006103e8610c6260025490565b610c6d906001612c94565b610c779190612cbf565b610c819190612cbf565b811015610ce85760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e312560881b6064820152608401610ade565b610cfa81670de0b6b3a7640000612c94565b60115550565b600554600114610d235760405163558a1e0360e11b815260040160405180910390fd5b60026005556064610d3360025490565b610d3d9190612cbf565b811115610da65760405162461bcd60e51b815260206004820152603160248201527f43616e206e6f7420666c6970206d6f7265207468616e203125206f662074686560448201527020737570706c7920617420612074696d6560781b6064820152608401610ade565b335f908152600d602052604090205415610df85760405162461bcd60e51b81526020600482015260136024820152724f6e6520666c697020617420612074696d652160681b6044820152606401610ade565b601b54341015610e405760405162461bcd60e51b8152602060048201526013602482015272496e73756666696369656e742056524646656560681b6044820152606401610ade565b601054601b546040515f926001600160a01b031691908381818185875af1925050503d805f8114610e8c576040519150601f19603f3d011682016040523d82523d5f602084013e610e91565b606091505b5050905080610eda5760405162461bcd60e51b81526020600482015260156024820152744661696c656420746f2073656e642056524646656560581b6044820152606401610ade565b610ee43383611b77565b6008546040805160c081018252600a548152600954602080830191909152600b5461ffff6401000000008204168385015263ffffffff808216606085015266010000000000009091041660808301528251908101909252600182525f926001600160a01b031691639b1c385e919060a0820190610f6090611c68565b8152506040518263ffffffff1660e01b8152600401610f7f9190612cd2565b6020604051808303815f875af1158015610f9b573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fbf9190612d36565b5f818152600c6020908152604080832080546001600160a01b031916339081179091558352600d909152902081905590506064610ffd8460c7612c94565b6110079190612cbf565b335f818152600e6020526040908190209290925590517feb60f01d57d2fe4e66ef31e4b2166288174d4cf64772f0a4e59d66e6a4a832589061104c9086815260200190565b60405180910390a25050600160055550565b5f61106a848484611cd9565b6001600160a01b0384165f908152600160209081526040808320338085529252909120546110a491869161109f908690612d4d565b611879565b5060019392505050565b6110b6611824565b67016345785d8a000081111561110e5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702056524620666565203c3d20302e3120455448000000006044820152606401610ade565b601b55565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612c49565b611151611824565b60405133904780156108fc02915f818181858888f1935050505015801561117a573d5f803e3d5ffd5b50565b611185611824565b601682905560178190556111998183612c49565b601581905560141015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c6573730000006044820152606401610ade565b5f6111f7611824565b506014805460ff19169055600190565b61120f611824565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b6007546001600160a01b0316331461128c5760405162461bcd60e51b815260206004820152601660248201527526bab9ba10313290383937b837b9b2b21037bbb732b960511b6044820152606401610ade565b600680546001600160a01b0319808216339081179093556007805490911690556040516001600160a01b03909116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b6112ee611824565b6014805462ffff00191662010100179055565b6006546001600160a01b0316331480159061132757506008546001600160a01b03163314155b15611378573361133f6006546001600160a01b031690565b60085460405163061db9c160e01b81526001600160a01b0393841660048201529183166024830152919091166044820152606401610ade565b6001600160a01b03811661139f5760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b0383169081179091556040519081527fd1a6a14209a385a964d036e404cb5cfb71f4000cdb03c9366292430787261be69060200160405180910390a150565b6113fb611824565b60148054911515620100000262ff000019909216919091179055565b606060048054610afa90612c5c565b61142e611824565b610ae7828261235e565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612d4d565b5f610b87338484611cd9565b611482611824565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6114e8611824565b806114f4816001611207565b600f80546001600160a01b0319166001600160a01b039290921691909117905550565b61151f611824565b670de0b6b3a76400006103e861153460025490565b61153f906005612c94565b6115499190612cbf565b6115539190612cbf565b8110156115ae5760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263302e352560e01b6064820152608401610ade565b6115c081670de0b6b3a7640000612c94565b60135550565b6115ce611824565b3063095ea7b3816115de60025490565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af1158015611626573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061164a9190612d60565b50306323b872dd816116646006546001600160a01b031690565b305f908152602081905260409020546040516001600160e01b031960e086901b1681526001600160a01b03938416600482015292909116602483015260448201526064016020604051808303815f875af11580156116c4573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a9190612d60565b5f6116f1611824565b620186a06116fe60025490565b611709906001612c94565b6117139190612cbf565b8210156117805760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ade565b606461178b60025490565b611796906001612c94565b6117a09190612cbf565b82111561180a5760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ade565b50601255600190565b61181b611824565b61117a816123b0565b6006546001600160a01b031633146118775760405162461bcd60e51b815260206004820152601660248201527527b7363c9031b0b63630b1363290313c9037bbb732b960511b6044820152606401610ade565b565b6001600160a01b0383166118db5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ade565b6001600160a01b03821661193c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ade565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b5f838152600c60205260409020546001600160a01b031680611a015760405162461bcd60e51b815260206004820152601a60248201527f4e6f2067616d6520666f756e6420666f722074686520757365720000000000006044820152606401610ade565b5f83835f818110611a1457611a14612d7b565b90506020020135905084600d5f846001600160a01b03166001600160a01b031681526020019081526020015f205403611b70575f611a53600283612d8f565b9050805f03611ae9576001600160a01b0383165f908152600e6020526040902054611a7f908490612459565b6001600160a01b0383165f818152600e6020526040908190205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad991611adc9185916001919283529015156020830152604082015260600190565b60405180910390a2611b49565b6001600160a01b0383165f818152600e60205260408082205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad992611b40928683529015156020830152604082015260600190565b60405180910390a25b506001600160a01b0382165f908152600e60209081526040808320839055600d9091528120555b5050505050565b6001600160a01b038216611bd75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610ade565b6001600160a01b0382165f90815260208190526040902054611bfa908290612d4d565b6001600160a01b0383165f90815260208190526040902055600254611c20908290612d4d565b6002556040518181525f906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020015b60405180910390a35050565b60607f92fd13387c7fe7befbc38d303d6468778fb9731bc4583f17d92989c6fcfdeaaa82604051602401611ca191511515815260200190565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b03199093169290921790915292915050565b6001600160a01b038316611cff5760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b038216611d255760405162461bcd60e51b8152600401610ade90612de7565b805f03611d3757610c4083835f612530565b60145460ff16156120a2576006546001600160a01b03848116911614801590611d6e57506006546001600160a01b03838116911614155b8015611d8257506001600160a01b03821615155b8015611d9957506001600160a01b03821661dead14155b8015611daf5750600f54600160a01b900460ff16155b156120a257601454610100900460ff16611e45576001600160a01b0383165f908152601e602052604090205460ff1680611e0057506001600160a01b0382165f908152601e602052604090205460ff165b611e455760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610ade565b6001600160a01b0383165f90815260208052604090205460ff168015611e8357506001600160a01b0382165f908152601f602052604090205460ff16155b15611f6657601154811115611ef85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ade565b6013546001600160a01b0383165f90815260208190526040902054611f1d9083612c49565b1115611f615760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b6120a2565b6001600160a01b0382165f90815260208052604090205460ff168015611fa457506001600160a01b0383165f908152601f602052604090205460ff16155b1561201a57601154811115611f615760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ade565b6001600160a01b0382165f908152601f602052604090205460ff166120a2576013546001600160a01b0383165f9081526020819052604090205461205e9083612c49565b11156120a25760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b305f90815260208190526040902054601254811080159081906120cd575060145462010000900460ff165b80156120e35750600f54600160a01b900460ff16155b801561210657506001600160a01b0385165f90815260208052604090205460ff16155b801561212a57506001600160a01b0385165f908152601e602052604090205460ff16155b801561214e57506001600160a01b0384165f908152601e602052604090205460ff16155b1561217c57600f805460ff60a01b1916600160a01b17905561216e61261e565b600f805460ff60a01b191690555b600f546001600160a01b0386165f908152601e602052604090205460ff600160a01b9092048216159116806121c857506001600160a01b0385165f908152601e602052604090205460ff165b156121d057505f5b5f811561234a576001600160a01b0386165f90815260208052604090205460ff1680156121fe57505f601854115b15612284576064601854866122139190612c94565b61221d9190612cbf565b9050601854601954826122309190612c94565b61223a9190612cbf565b601c5f82825461224a9190612c49565b9091555050601854601a5461225f9083612c94565b6122699190612cbf565b601d5f8282546122799190612c49565b9091555061232c9050565b6001600160a01b0387165f90815260208052604090205460ff1680156122ab57505f601554115b1561232c576064601554866122c09190612c94565b6122ca9190612cbf565b9050601554601654826122dd9190612c94565b6122e79190612cbf565b601c5f8282546122f79190612c49565b909155505060155460175461230c9083612c94565b6123169190612cbf565b601d5f8282546123269190612c49565b90915550505b801561233d5761233d873083612530565b6123478186612d4d565b94505b612355878787612530565b50505050505050565b6001600160a01b0382165f818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b336001600160a01b038216036124085760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c660000000000000000006044820152606401610ade565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b6001600160a01b0382166124af5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610ade565b806002546124bd9190612c49565b6002556001600160a01b0382165f908152602081905260409020546124e3908290612c49565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611c5c565b6001600160a01b0383166125565760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b03821661257c5760405162461bcd60e51b8152600401610ade90612de7565b6001600160a01b0383165f9081526020819052604090205461259f908290612d4d565b6001600160a01b038085165f9081526020819052604080822093909355908416815220546125ce908290612c49565b6001600160a01b038381165f818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611990565b305f9081526020819052604081205490505f601d54601c546126409190612c49565b90505f82158061264e575081155b1561265857505050565b601254612666906014612c94565b83111561267e5760125461267b906014612c94565b92505b5f600283601c54866126909190612c94565b61269a9190612cbf565b6126a49190612cbf565b90505f6126b18286612d4d565b9050476126bd8261280e565b5f6126c88247612d4d565b90505f86601d54836126da9190612c94565b6126e49190612cbf565b90505f6126f18284612d4d565b5f601c819055601d8190556010546040519293506001600160a01b031691849181818185875af1925050503d805f8114612746576040519150601f19603f3d011682016040523d82523d5f602084013e61274b565b606091505b5090975050851580159061275e57505f81115b156127b15761276d868261295e565b601c54604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6010546040516001600160a01b039091169047905f81818185875af1925050503d805f81146127fb576040519150601f19603f3d011682016040523d82523d5f602084013e612800565b606091505b505050505050505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061284157612841612d7b565b6001600160a01b03928316602091820292909201810191909152600f54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612898573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906128bc9190612e2a565b816001815181106128cf576128cf612d7b565b6001600160a01b039283166020918202929092010152600f546128f59130911684611879565b600f5460405163791ac94760e01b81526001600160a01b039091169063791ac9479061292d9085905f90869030904290600401612e45565b5f604051808303815f87803b158015612944575f80fd5b505af1158015612956573d5f803e3d5ffd5b505050505050565b600f546129769030906001600160a01b031684611879565b600f5460105460405163f305d71960e01b8152306004820152602481018590525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af11580156129e3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611b709190612eb4565b5f8060408385031215612a19575f80fd5b50508035926020909101359150565b5f81518084525f5b81811015612a4c57602081850181015186830182015201612a30565b505f602082860101526020601f19601f83011685010191505092915050565b602081525f612a7d6020830184612a28565b9392505050565b6001600160a01b038116811461117a575f80fd5b5f8060408385031215612aa9575f80fd5b8235612ab481612a84565b946020939093013593505050565b5f60208284031215612ad2575f80fd5b8135612a7d81612a84565b5f805f60408486031215612aef575f80fd5b83359250602084013567ffffffffffffffff80821115612b0d575f80fd5b818601915086601f830112612b20575f80fd5b813581811115612b2e575f80fd5b8760208260051b8501011115612b42575f80fd5b6020830194508093505050509250925092565b5f60208284031215612b65575f80fd5b5035919050565b5f805f60608486031215612b7e575f80fd5b8335612b8981612a84565b92506020840135612b9981612a84565b929592945050506040919091013590565b801515811461117a575f80fd5b5f8060408385031215612bc8575f80fd5b8235612bd381612a84565b91506020830135612be381612baa565b809150509250929050565b5f60208284031215612bfe575f80fd5b8135612a7d81612baa565b5f8060408385031215612c1a575f80fd5b8235612c2581612a84565b91506020830135612be381612a84565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b8b57610b8b612c35565b600181811c90821680612c7057607f821691505b602082108103612c8e57634e487b7160e01b5f52602260045260245ffd5b50919050565b8082028115828204841417610b8b57610b8b612c35565b634e487b7160e01b5f52601260045260245ffd5b5f82612ccd57612ccd612cab565b500490565b60208152815160208201526020820151604082015261ffff60408301511660608201525f606083015163ffffffff80821660808501528060808601511660a0850152505060a083015160c080840152612d2e60e0840182612a28565b949350505050565b5f60208284031215612d46575f80fd5b5051919050565b81810381811115610b8b57610b8b612c35565b5f60208284031215612d70575f80fd5b8151612a7d81612baa565b634e487b7160e01b5f52603260045260245ffd5b5f82612d9d57612d9d612cab565b500690565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b5f60208284031215612e3a575f80fd5b8151612a7d81612a84565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015612e935784516001600160a01b031683529383019391830191600101612e6e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215612ec6575f80fd5b835192506020840151915060408401519050925092509256fea264697066735822122014be96ed9d9fb8d1b8c3c6e9e26a76af88c3b76cdba8357b467974145befaba764736f6c63430008140033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71
-----Decoded View---------------
Arg [0] : subscriptionId (uint256): 66962744969274724259737974286973259105020480573706440157425268360644436307569
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71
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 ]
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.