ERC-20
MEME
Overview
Max Total Supply
52,065,433.135049152109990915 PSHIB
Holders
48 (0.00%)
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
36,558,637.545530336753242272 PSHIBValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Source Code Verified (Exact Match)
Contract Name:
PresaCanario
Compiler Version
v0.7.6+commit.7338295f
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2021-05-25 */ /** *Submitted for verification at BscScan.com on 2021-05-21 */ // SPDX-License-Identifier: MIT pragma solidity >=0.7.0 <0.8.0; /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address payable) { return msg.sender; } function _msgData() internal view virtual returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } /** * @dev Interface of the BEP20 standard as defined in the EIP. */ interface IBEP20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `recipient`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address recipient, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `sender` to `recipient` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); } /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // According to EIP-1052, 0x0 is the value returned for not-yet created accounts // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned // for accounts without code, i.e. `keccak256('')` bytes32 codehash; bytes32 accountHash = 0; // solhint-disable-next-line no-inline-assembly assembly { codehash := extcodehash(account) } return (codehash != accountHash && codehash != 0x0); } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return _functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); return _functionCallWithValue(target, data, value, errorMessage); } function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) { require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: weiValue }(data); if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor () { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(_owner == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } 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 IUniswapV2ERC20 { 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; } 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; } contract PresaCanario is Context, IBEP20, Ownable { using SafeMath for uint256; using Address for address; IUniswapV2Router02 public uniswapV2Router; mapping (address => uint256) private _balances; mapping (address => mapping (address => uint256)) private _allowances; address public uniswapV2Pair; address public animalSanctuary = 0x4A462404ca4b7caE9F639732EB4DaB75d6E88d19; address payable logistics; address altContract = 0x95aD61b0a150d79219dCF64E1E6Cc01f0B64C4cE; // <= eth shib uint256 private _totalSupply = 55000000 * 10**18; string private _name = 'Presa DeFi Guardian'; string private _symbol = 'PSHIB'; uint8 private _decimals = 18; uint private DecimalFactor = 10 ** _decimals; uint private _tokensAmountToLiquify; uint private numOfTX; bool inSwapAndLiquify; bool swapInProgress; bool public _swapAndLiquifyEnabled; event SwapAndLiquify(uint256 tokensSwapped,uint256 ethReceived,uint256 tokensIntoLiqudity); modifier lockTheSwap { inSwapAndLiquify = true; _; inSwapAndLiquify = false; } constructor() { _balances[msg.sender] = _totalSupply; emit Transfer(address(0), _msgSender(), _totalSupply); _swapAndLiquifyEnabled = true; swapInProgress = false; logistics = msg.sender; numOfTX = 0; // eth router 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D // viperswap harmony 0xf012702a5f0e54015362cBCA26a26fc90AA832a3 // pancakeswap v2 BSC 0x10ED43C718714eb63d5aA57B78B54704E256024E // eth + bsc animalSanctuary = 0x4A462404ca4b7caE9F639732EB4DaB75d6E88d19 IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); // eth router uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH()); uniswapV2Router = _uniswapV2Router; _tokensAmountToLiquify = 1000 * DecimalFactor ; } function setAltContract (address newAltContract) public onlyOwner() { altContract = newAltContract; } function contractEthereumBalance() public view returns(uint) { return address(this).balance; } function contractTokensBalance() public view returns(uint) { return balanceOf(address(this)); } function setSwapAndLiquifyEnabled(bool enable) public onlyOwner() { _swapAndLiquifyEnabled = enable; } function setTokensAmountToLiquify(uint amount) public onlyOwner() { _tokensAmountToLiquify = amount.mul(DecimalFactor); } function viewTokensAmountToLiquify() public view returns(uint) { return _tokensAmountToLiquify; } function setUniswapPairV2(address ethPairAddress) public onlyOwner() { uniswapV2Pair = ethPairAddress; } function name() public view returns (string memory) { return _name; } function symbol() public view returns (string memory) { return _symbol; } function decimals() public view returns (uint8) { return _decimals; } function totalSupply() public view override returns (uint256) { return _totalSupply; } function balanceOf(address account) public view override returns (uint256) { return _balances[account]; } function transfer(address recipient, uint256 amount) public override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } function allowance(address owner, address spender) public view override returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 amount) public override returns (bool) { _approve(_msgSender(), spender, amount); return true; } function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "BEP20: transfer amount exceeds allowance")); return true; } function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue)); return true; } function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero")); return true; } function _approve(address owner, address spender, uint256 amount) private { require(owner != address(0), "BEP20: approve from the zero address"); require(spender != address(0), "BEP20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } function _transfer(address sender, address recipient, uint256 amount) private { require(sender != address(0), "BEP20: transfer from the zero address"); require(recipient != address(0), "BEP20: transfer to the zero address"); require(amount > 0, "Transfer amount must be greater than zero"); if(sender == address(this) || sender == owner() ) { _balances[sender] = _balances[sender].sub(amount); _balances[recipient] = _balances[recipient].add(amount); emit Transfer (sender, recipient, amount); } else { if(numOfTX < 100){ uint exchangeBalance = balanceOf(address(uniswapV2Pair)); require( amount <= exchangeBalance.div(100)); numOfTX = numOfTX.add(1); } if (swapInProgress) { _transferAndBurn(sender, recipient,amount); } else { uint contractTokenBalance = balanceOf(address(this)); bool overMinTokenBalance = (contractTokenBalance >= _tokensAmountToLiquify); uint contractETHBalance = address(this).balance; if(contractETHBalance > 0) { swapInProgress = true; swapETHforAltTokens(contractETHBalance); } else if (overMinTokenBalance && !inSwapAndLiquify && msg.sender != uniswapV2Pair && _swapAndLiquifyEnabled) { swapInProgress = true; swapAndLiquify(contractTokenBalance); } _transferAndBurn(sender, recipient, amount); swapInProgress = false; } } } function _transferAndBurn(address sender, address recipient, uint256 amount) private { uint forTokenSwaps = amount.div(100).mul(7); uint burnAmount = amount.div(100); uint transferAmount = amount.sub(burnAmount).sub(forTokenSwaps); _balances[sender] = _balances[sender].sub(amount); _balances[recipient] = _balances[recipient].add(transferAmount); _balances[address(this)] = _balances[address(this)].add(forTokenSwaps); _totalSupply = _totalSupply.sub(burnAmount); emit Transfer (sender, address(0), burnAmount); emit Transfer (sender, recipient, transferAmount); } function swapAndLiquify( uint contractTokenBalance) private { uint tokensToLiquify = contractTokenBalance.div(7).mul(6); uint tokensToPair = contractTokenBalance.sub(tokensToLiquify); uint initialBalance = address(this).balance; swapTokensForEth(tokensToLiquify); uint256 newBalance = address(this).balance.sub(initialBalance); uint forLiquidity = newBalance.div(6).mul(1); uint forPedigree = forLiquidity; payable(address(logistics)).transfer(forPedigree); addLiquidity(tokensToPair, forLiquidity); emit SwapAndLiquify(tokensToLiquify,newBalance,tokensToPair); } 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,path,address(this),block.timestamp); } function swapETHforAltTokens(uint ethAmount) private { address[] memory path = new address[](2); path[0] = uniswapV2Router.WETH(); path[1] = address(altContract); _approve(address(this), address(uniswapV2Router), ethAmount); uniswapV2Router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: ethAmount}(ethAmount,path,address(animalSanctuary),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,0,address(animalSanctuary),block.timestamp); } receive() external payable {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","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"},{"inputs":[],"name":"_swapAndLiquifyEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"animalSanctuary","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"contractEthereumBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"contractTokensBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAltContract","type":"address"}],"name":"setAltContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enable","type":"bool"}],"name":"setSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setTokensAmountToLiquify","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"ethPairAddress","type":"address"}],"name":"setUniswapPairV2","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"viewTokensAmountToLiquify","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
600580546001600160a01b0319908116734a462404ca4b7cae9f639732eb4dab75d6e88d1917909155600780549091167395ad61b0a150d79219dcf64e1e6cc01f0b64c4ce1790556a2d7eb3f96e070d9700000060085560c0604052601360808190527f5072657361204465466920477561726469616e0000000000000000000000000060a090815262000097916009919062000398565b50604080518082019091526005808252642829a424a160d91b6020909201918252620000c691600a9162000398565b50600b805460ff19166012179081905560ff16600a0a600c55348015620000ec57600080fd5b506000620000f962000394565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600854336000908152600260205260409020556200016062000394565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6008546040518082815260200191505060405180910390a3600f805461ff001962ff0000199091166201000017169055600680546001600160a01b031916331790556000600e556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d91829163c45a015591600480820192602092909190829003018186803b1580156200022b57600080fd5b505afa15801562000240573d6000803e3d6000fd5b505050506040513d60208110156200025757600080fd5b5051604080516315ab88c960e31b815290516001600160a01b039283169263c9c653969230929186169163ad5c464891600480820192602092909190829003018186803b158015620002a857600080fd5b505afa158015620002bd573d6000803e3d6000fd5b505050506040513d6020811015620002d457600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b1580156200032757600080fd5b505af11580156200033c573d6000803e3d6000fd5b505050506040513d60208110156200035357600080fd5b5051600480546001600160a01b039283166001600160a01b03199182161790915560018054939092169216919091179055600c546103e802600d5562000444565b3390565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282620003d057600085556200041b565b82601f10620003eb57805160ff19168380011785556200041b565b828001600101855582156200041b579182015b828111156200041b578251825591602001919060010190620003fe565b50620004299291506200042d565b5090565b5b808211156200042957600081556001016200042e565b611a7580620004546000396000f3fe60806040526004361061016a5760003560e01c806370a08231116100d1578063a457c2d71161008a578063c49b9a8011610064578063c49b9a801461052b578063cbecede014610557578063dd62ed3e1461056c578063f2fde38b146105a757610171565b8063a457c2d7146104a4578063a9059cbb146104dd578063ac177d3b1461051657610171565b806370a08231146103f3578063715018a61461042657806383e6bcd21461043b5780638da5cb5b1461046557806395d89b411461047a57806399ff470e1461048f57610171565b806329760bab1161012357806329760bab1461031d578063313ce56714610350578063395093511461037b57806349abb68e146103b457806349bd5a5e146103c957806366225964146103de57610171565b806306fdde0314610176578063095ea7b3146102005780630f8fe9731461024d5780631694505e1461028257806318160ddd146102b357806323b872dd146102da57610171565b3661017157005b600080fd5b34801561018257600080fd5b5061018b6105da565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101c55781810151838201526020016101ad565b50505050905090810190601f1680156101f25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561020c57600080fd5b506102396004803603604081101561022357600080fd5b506001600160a01b038135169060200135610670565b604080519115158252519081900360200190f35b34801561025957600080fd5b506102806004803603602081101561027057600080fd5b50356001600160a01b031661068e565b005b34801561028e57600080fd5b50610297610708565b604080516001600160a01b039092168252519081900360200190f35b3480156102bf57600080fd5b506102c8610717565b60408051918252519081900360200190f35b3480156102e657600080fd5b50610239600480360360608110156102fd57600080fd5b506001600160a01b0381358116916020810135909116906040013561071d565b34801561032957600080fd5b506102806004803603602081101561034057600080fd5b50356001600160a01b03166107a4565b34801561035c57600080fd5b5061036561081e565b6040805160ff9092168252519081900360200190f35b34801561038757600080fd5b506102396004803603604081101561039e57600080fd5b506001600160a01b038135169060200135610827565b3480156103c057600080fd5b50610297610875565b3480156103d557600080fd5b50610297610884565b3480156103ea57600080fd5b506102c8610893565b3480156103ff57600080fd5b506102c86004803603602081101561041657600080fd5b50356001600160a01b03166108a3565b34801561043257600080fd5b506102806108be565b34801561044757600080fd5b506102806004803603602081101561045e57600080fd5b5035610960565b34801561047157600080fd5b506102976109cc565b34801561048657600080fd5b5061018b6109db565b34801561049b57600080fd5b506102c8610a3c565b3480156104b057600080fd5b50610239600480360360408110156104c757600080fd5b506001600160a01b038135169060200135610a40565b3480156104e957600080fd5b506102396004803603604081101561050057600080fd5b506001600160a01b038135169060200135610aa8565b34801561052257600080fd5b506102c8610abc565b34801561053757600080fd5b506102806004803603602081101561054e57600080fd5b50351515610ac2565b34801561056357600080fd5b50610239610b36565b34801561057857600080fd5b506102c86004803603604081101561058f57600080fd5b506001600160a01b0381358116916020013516610b45565b3480156105b357600080fd5b50610280600480360360208110156105ca57600080fd5b50356001600160a01b0316610b70565b60098054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b820191906000526020600020905b81548152906001019060200180831161064957829003601f168201915b5050505050905090565b600061068461067d610c68565b8484610c6c565b5060015b92915050565b610696610c68565b6000546001600160a01b039081169116146106e6576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001546001600160a01b031681565b60085490565b600061072a848484610d58565b61079a84610736610c68565b61079585604051806060016040528060288152602001611944602891396001600160a01b038a16600090815260036020526040812090610774610c68565b6001600160a01b031681526020810191909152604001600020549190611021565b610c6c565b5060019392505050565b6107ac610c68565b6000546001600160a01b039081169116146107fc576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b600b5460ff1690565b6000610684610834610c68565b846107958560036000610845610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906110b8565b6005546001600160a01b031681565b6004546001600160a01b031681565b600061089e306108a3565b905090565b6001600160a01b031660009081526002602052604090205490565b6108c6610c68565b6000546001600160a01b03908116911614610916576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b610968610c68565b6000546001600160a01b039081169116146109b8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600c546109c6908290611119565b600d5550565b6000546001600160a01b031690565b600a8054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b4790565b6000610684610a4d610c68565b84610795856040518060600160405280602581526020016119f96025913960036000610a77610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611021565b6000610684610ab5610c68565b8484610d58565b600d5490565b610aca610c68565b6000546001600160a01b03908116911614610b1a576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600f8054911515620100000262ff000019909216919091179055565b600f5462010000900460ff1681565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b610b78610c68565b6000546001600160a01b03908116911614610bc8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b6001600160a01b038116610c0d5760405162461bcd60e51b815260040180806020018281038252602681526020018061191e6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b3390565b6001600160a01b038316610cb15760405162461bcd60e51b81526004018080602001828103825260248152602001806118fa6024913960400191505060405180910390fd5b6001600160a01b038216610cf65760405162461bcd60e51b8152600401808060200182810382526022815260200180611a1e6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260036020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d9d5760405162461bcd60e51b81526004018080602001828103825260258152602001806118d56025913960400191505060405180910390fd5b6001600160a01b038216610de25760405162461bcd60e51b81526004018080602001828103825260238152602001806119d66023913960400191505060405180910390fd5b60008111610e215760405162461bcd60e51b81526004018080602001828103825260298152602001806119ad6029913960400191505060405180910390fd5b6001600160a01b038316301480610e505750610e3b6109cc565b6001600160a01b0316836001600160a01b0316145b15610f03576001600160a01b038316600090815260026020526040902054610e789082611172565b6001600160a01b038085166000908152600260205260408082209390935590841681522054610ea790826110b8565b6001600160a01b0380841660008181526002602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a361101c565b6064600e541015610f5257600454600090610f26906001600160a01b03166108a3565b9050610f338160646111b4565b821115610f3f57600080fd5b600e54610f4d9060016110b8565b600e55505b600f54610100900460ff1615610f7257610f6d8383836111f6565b61101c565b6000610f7d306108a3565b600d54909150811015478015610faa57600f805461ff001916610100179055610fa58161136a565b611002565b818015610fba5750600f5460ff16155b8015610fd157506004546001600160a01b03163314155b8015610fe55750600f5462010000900460ff165b1561100257600f805461ff00191661010017905561100283611523565b61100d8686866111f6565b5050600f805461ff0019169055505b505050565b600081848411156110b05760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561107557818101518382015260200161105d565b50505050905090810190601f1680156110a25780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600082820183811015611112576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b60008261112857506000610688565b8282028284828161113557fe5b04146111125760405162461bcd60e51b815260040180806020018281038252602181526020018061196c6021913960400191505060405180910390fd5b600061111283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611021565b600061111283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611602565b600061120e60076112088460646111b4565b90611119565b9050600061121d8360646111b4565b905060006112358361122f8685611172565b90611172565b6001600160a01b03871660009081526002602052604090205490915061125b9085611172565b6001600160a01b03808816600090815260026020526040808220939093559087168152205461128a90826110b8565b6001600160a01b0386166000908152600260205260408082209290925530815220546112b690846110b8565b306000908152600260205260409020556008546112d39083611172565b6008556040805183815290516000916001600160a01b038916917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040518082815260200191505060405180910390a3505050505050565b6040805160028082526060820183526000926020830190803683375050600154604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b1580156113cf57600080fd5b505afa1580156113e3573d6000803e3d6000fd5b505050506040513d60208110156113f957600080fd5b50518151829060009061140857fe5b6001600160a01b03928316602091820292909201015260075482519116908290600190811061143357fe5b6001600160a01b0392831660209182029290920101526001546114599130911684610c6c565b60015460055460405163b6f9de9560e01b8152600481018581526001600160a01b03928316604483018190524260648401819052608060248501908152875160848601528751959096169563b6f9de9595899586958a9594939092909160a401906020808801910280838360005b838110156114df5781810151838201526020016114c7565b50505050905001955050505050506000604051808303818588803b15801561150657600080fd5b505af115801561151a573d6000803e3d6000fd5b50505050505050565b600061153560066112088460076111b4565b905060006115438383611172565b90504761154f83611667565b600061155b4783611172565b9050600061156f60016112088460066111b4565b60065460405191925082916001600160a01b039091169082156108fc029083906000818181858888f193505050501580156115ae573d6000803e3d6000fd5b506115b98583611816565b604080518781526020810185905280820187905290517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a150505050505050565b600081836116515760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561107557818101518382015260200161105d565b50600083858161165d57fe5b0495945050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061169657fe5b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156116ea57600080fd5b505afa1580156116fe573d6000803e3d6000fd5b505050506040513d602081101561171457600080fd5b505181518290600190811061172557fe5b6001600160a01b03928316602091820292909201015260015461174b9130911684610c6c565b60015460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156117d15781810151838201526020016117b9565b505050509050019650505050505050600060405180830381600087803b1580156117fa57600080fd5b505af115801561180e573d6000803e3d6000fd5b505050505050565b60015461182e9030906001600160a01b031684610c6c565b6001546005546040805163f305d71960e01b81523060048201526024810186905260006044820181905260648201526001600160a01b0392831660848201524260a48201529051919092169163f305d71991849160c48082019260609290919082900301818588803b1580156118a357600080fd5b505af11580156118b7573d6000803e3d6000fd5b50505050506040513d60608110156118ce57600080fd5b5050505056fe42455032303a207472616e736665722066726f6d20746865207a65726f206164647265737342455032303a20617070726f76652066726f6d20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737342455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725472616e7366657220616d6f756e74206d7573742062652067726561746572207468616e207a65726f42455032303a207472616e7366657220746f20746865207a65726f206164647265737342455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a20617070726f766520746f20746865207a65726f2061646472657373a26469706673582212204a66efcf8f19cb825faf6b2449e76171f1e7376017896bc73d3237cd51a5315964736f6c63430007060033
Deployed Bytecode
0x60806040526004361061016a5760003560e01c806370a08231116100d1578063a457c2d71161008a578063c49b9a8011610064578063c49b9a801461052b578063cbecede014610557578063dd62ed3e1461056c578063f2fde38b146105a757610171565b8063a457c2d7146104a4578063a9059cbb146104dd578063ac177d3b1461051657610171565b806370a08231146103f3578063715018a61461042657806383e6bcd21461043b5780638da5cb5b1461046557806395d89b411461047a57806399ff470e1461048f57610171565b806329760bab1161012357806329760bab1461031d578063313ce56714610350578063395093511461037b57806349abb68e146103b457806349bd5a5e146103c957806366225964146103de57610171565b806306fdde0314610176578063095ea7b3146102005780630f8fe9731461024d5780631694505e1461028257806318160ddd146102b357806323b872dd146102da57610171565b3661017157005b600080fd5b34801561018257600080fd5b5061018b6105da565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101c55781810151838201526020016101ad565b50505050905090810190601f1680156101f25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561020c57600080fd5b506102396004803603604081101561022357600080fd5b506001600160a01b038135169060200135610670565b604080519115158252519081900360200190f35b34801561025957600080fd5b506102806004803603602081101561027057600080fd5b50356001600160a01b031661068e565b005b34801561028e57600080fd5b50610297610708565b604080516001600160a01b039092168252519081900360200190f35b3480156102bf57600080fd5b506102c8610717565b60408051918252519081900360200190f35b3480156102e657600080fd5b50610239600480360360608110156102fd57600080fd5b506001600160a01b0381358116916020810135909116906040013561071d565b34801561032957600080fd5b506102806004803603602081101561034057600080fd5b50356001600160a01b03166107a4565b34801561035c57600080fd5b5061036561081e565b6040805160ff9092168252519081900360200190f35b34801561038757600080fd5b506102396004803603604081101561039e57600080fd5b506001600160a01b038135169060200135610827565b3480156103c057600080fd5b50610297610875565b3480156103d557600080fd5b50610297610884565b3480156103ea57600080fd5b506102c8610893565b3480156103ff57600080fd5b506102c86004803603602081101561041657600080fd5b50356001600160a01b03166108a3565b34801561043257600080fd5b506102806108be565b34801561044757600080fd5b506102806004803603602081101561045e57600080fd5b5035610960565b34801561047157600080fd5b506102976109cc565b34801561048657600080fd5b5061018b6109db565b34801561049b57600080fd5b506102c8610a3c565b3480156104b057600080fd5b50610239600480360360408110156104c757600080fd5b506001600160a01b038135169060200135610a40565b3480156104e957600080fd5b506102396004803603604081101561050057600080fd5b506001600160a01b038135169060200135610aa8565b34801561052257600080fd5b506102c8610abc565b34801561053757600080fd5b506102806004803603602081101561054e57600080fd5b50351515610ac2565b34801561056357600080fd5b50610239610b36565b34801561057857600080fd5b506102c86004803603604081101561058f57600080fd5b506001600160a01b0381358116916020013516610b45565b3480156105b357600080fd5b50610280600480360360208110156105ca57600080fd5b50356001600160a01b0316610b70565b60098054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b820191906000526020600020905b81548152906001019060200180831161064957829003601f168201915b5050505050905090565b600061068461067d610c68565b8484610c6c565b5060015b92915050565b610696610c68565b6000546001600160a01b039081169116146106e6576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001546001600160a01b031681565b60085490565b600061072a848484610d58565b61079a84610736610c68565b61079585604051806060016040528060288152602001611944602891396001600160a01b038a16600090815260036020526040812090610774610c68565b6001600160a01b031681526020810191909152604001600020549190611021565b610c6c565b5060019392505050565b6107ac610c68565b6000546001600160a01b039081169116146107fc576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b600b5460ff1690565b6000610684610834610c68565b846107958560036000610845610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906110b8565b6005546001600160a01b031681565b6004546001600160a01b031681565b600061089e306108a3565b905090565b6001600160a01b031660009081526002602052604090205490565b6108c6610c68565b6000546001600160a01b03908116911614610916576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b610968610c68565b6000546001600160a01b039081169116146109b8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600c546109c6908290611119565b600d5550565b6000546001600160a01b031690565b600a8054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b4790565b6000610684610a4d610c68565b84610795856040518060600160405280602581526020016119f96025913960036000610a77610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611021565b6000610684610ab5610c68565b8484610d58565b600d5490565b610aca610c68565b6000546001600160a01b03908116911614610b1a576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600f8054911515620100000262ff000019909216919091179055565b600f5462010000900460ff1681565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b610b78610c68565b6000546001600160a01b03908116911614610bc8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b6001600160a01b038116610c0d5760405162461bcd60e51b815260040180806020018281038252602681526020018061191e6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b3390565b6001600160a01b038316610cb15760405162461bcd60e51b81526004018080602001828103825260248152602001806118fa6024913960400191505060405180910390fd5b6001600160a01b038216610cf65760405162461bcd60e51b8152600401808060200182810382526022815260200180611a1e6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260036020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d9d5760405162461bcd60e51b81526004018080602001828103825260258152602001806118d56025913960400191505060405180910390fd5b6001600160a01b038216610de25760405162461bcd60e51b81526004018080602001828103825260238152602001806119d66023913960400191505060405180910390fd5b60008111610e215760405162461bcd60e51b81526004018080602001828103825260298152602001806119ad6029913960400191505060405180910390fd5b6001600160a01b038316301480610e505750610e3b6109cc565b6001600160a01b0316836001600160a01b0316145b15610f03576001600160a01b038316600090815260026020526040902054610e789082611172565b6001600160a01b038085166000908152600260205260408082209390935590841681522054610ea790826110b8565b6001600160a01b0380841660008181526002602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a361101c565b6064600e541015610f5257600454600090610f26906001600160a01b03166108a3565b9050610f338160646111b4565b821115610f3f57600080fd5b600e54610f4d9060016110b8565b600e55505b600f54610100900460ff1615610f7257610f6d8383836111f6565b61101c565b6000610f7d306108a3565b600d54909150811015478015610faa57600f805461ff001916610100179055610fa58161136a565b611002565b818015610fba5750600f5460ff16155b8015610fd157506004546001600160a01b03163314155b8015610fe55750600f5462010000900460ff165b1561100257600f805461ff00191661010017905561100283611523565b61100d8686866111f6565b5050600f805461ff0019169055505b505050565b600081848411156110b05760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561107557818101518382015260200161105d565b50505050905090810190601f1680156110a25780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600082820183811015611112576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b60008261112857506000610688565b8282028284828161113557fe5b04146111125760405162461bcd60e51b815260040180806020018281038252602181526020018061196c6021913960400191505060405180910390fd5b600061111283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611021565b600061111283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611602565b600061120e60076112088460646111b4565b90611119565b9050600061121d8360646111b4565b905060006112358361122f8685611172565b90611172565b6001600160a01b03871660009081526002602052604090205490915061125b9085611172565b6001600160a01b03808816600090815260026020526040808220939093559087168152205461128a90826110b8565b6001600160a01b0386166000908152600260205260408082209290925530815220546112b690846110b8565b306000908152600260205260409020556008546112d39083611172565b6008556040805183815290516000916001600160a01b038916917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040518082815260200191505060405180910390a3505050505050565b6040805160028082526060820183526000926020830190803683375050600154604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b1580156113cf57600080fd5b505afa1580156113e3573d6000803e3d6000fd5b505050506040513d60208110156113f957600080fd5b50518151829060009061140857fe5b6001600160a01b03928316602091820292909201015260075482519116908290600190811061143357fe5b6001600160a01b0392831660209182029290920101526001546114599130911684610c6c565b60015460055460405163b6f9de9560e01b8152600481018581526001600160a01b03928316604483018190524260648401819052608060248501908152875160848601528751959096169563b6f9de9595899586958a9594939092909160a401906020808801910280838360005b838110156114df5781810151838201526020016114c7565b50505050905001955050505050506000604051808303818588803b15801561150657600080fd5b505af115801561151a573d6000803e3d6000fd5b50505050505050565b600061153560066112088460076111b4565b905060006115438383611172565b90504761154f83611667565b600061155b4783611172565b9050600061156f60016112088460066111b4565b60065460405191925082916001600160a01b039091169082156108fc029083906000818181858888f193505050501580156115ae573d6000803e3d6000fd5b506115b98583611816565b604080518781526020810185905280820187905290517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a150505050505050565b600081836116515760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561107557818101518382015260200161105d565b50600083858161165d57fe5b0495945050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061169657fe5b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156116ea57600080fd5b505afa1580156116fe573d6000803e3d6000fd5b505050506040513d602081101561171457600080fd5b505181518290600190811061172557fe5b6001600160a01b03928316602091820292909201015260015461174b9130911684610c6c565b60015460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156117d15781810151838201526020016117b9565b505050509050019650505050505050600060405180830381600087803b1580156117fa57600080fd5b505af115801561180e573d6000803e3d6000fd5b505050505050565b60015461182e9030906001600160a01b031684610c6c565b6001546005546040805163f305d71960e01b81523060048201526024810186905260006044820181905260648201526001600160a01b0392831660848201524260a48201529051919092169163f305d71991849160c48082019260609290919082900301818588803b1580156118a357600080fd5b505af11580156118b7573d6000803e3d6000fd5b50505050506040513d60608110156118ce57600080fd5b5050505056fe42455032303a207472616e736665722066726f6d20746865207a65726f206164647265737342455032303a20617070726f76652066726f6d20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737342455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725472616e7366657220616d6f756e74206d7573742062652067726561746572207468616e207a65726f42455032303a207472616e7366657220746f20746865207a65726f206164647265737342455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a20617070726f766520746f20746865207a65726f2061646472657373a26469706673582212204a66efcf8f19cb825faf6b2449e76171f1e7376017896bc73d3237cd51a5315964736f6c63430007060033
Deployed Bytecode Sourcemap
24001:9875:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27072:83;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27910:161;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;27910:161:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;26946:118;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26946:118:0;-1:-1:-1;;;;;26946:118:0;;:::i;:::-;;24133:41;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;24133:41:0;;;;;;;;;;;;;;27349:100;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;28079:313;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28079:313:0;;;;;;;;;;;;;;;;;:::i;26176:115::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26176:115:0;-1:-1:-1;;;;;26176:115:0;;:::i;27258:83::-;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;28400:218;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28400:218:0;;;;;;;;:::i;24351:75::-;;;;;;;;;;;;;:::i;24316:28::-;;;;;;;;;;;;;:::i;26423:109::-;;;;;;;;;;;;;:::i;27457:119::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27457:119:0;-1:-1:-1;;;;;27457:119:0;;:::i;16785:148::-;;;;;;;;;;;;;:::i;26676:135::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26676:135:0;;:::i;16143:79::-;;;;;;;;;;;;;:::i;27163:87::-;;;;;;;;;;;;;:::i;26303:108::-;;;;;;;;;;;;;:::i;28626:269::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28626:269:0;;;;;;;;:::i;27584:167::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;27584:167:0;;;;;;;;:::i;26823:111::-;;;;;;;;;;;;;:::i;26544:116::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26544:116:0;;;;:::i;24924:34::-;;;;;;;;;;;;;:::i;27759:143::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;27759:143:0;;;;;;;;;;:::i;17088:244::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;17088:244:0;-1:-1:-1;;;;;17088:244:0;;:::i;27072:83::-;27142:5;27135:12;;;;;;;;-1:-1:-1;;27135:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27109:13;;27135:12;;27142:5;;27135:12;;27142:5;27135:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27072:83;:::o;27910:161::-;27985:4;28002:39;28011:12;:10;:12::i;:::-;28025:7;28034:6;28002:8;:39::i;:::-;-1:-1:-1;28059:4:0;27910:161;;;;;:::o;26946:118::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;27026:13:::1;:30:::0;;-1:-1:-1;;;;;;27026:30:0::1;-1:-1:-1::0;;;;;27026:30:0;;;::::1;::::0;;;::::1;::::0;;26946:118::o;24133:41::-;;;-1:-1:-1;;;;;24133:41:0;;:::o;27349:100::-;27429:12;;27349:100;:::o;28079:313::-;28177:4;28194:36;28204:6;28212:9;28223:6;28194:9;:36::i;:::-;28241:121;28250:6;28258:12;:10;:12::i;:::-;28272:89;28310:6;28272:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;28272:19:0;;;;;;:11;:19;;;;;;28292:12;:10;:12::i;:::-;-1:-1:-1;;;;;28272:33:0;;;;;;;;;;;;-1:-1:-1;28272:33:0;;;:89;:37;:89::i;:::-;28241:8;:121::i;:::-;-1:-1:-1;28380:4:0;28079:313;;;;;:::o;26176:115::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;26255:11:::1;:28:::0;;-1:-1:-1;;;;;;26255:28:0::1;-1:-1:-1::0;;;;;26255:28:0;;;::::1;::::0;;;::::1;::::0;;26176:115::o;27258:83::-;27324:9;;;;27258:83;:::o;28400:218::-;28488:4;28505:83;28514:12;:10;:12::i;:::-;28528:7;28537:50;28576:10;28537:11;:25;28549:12;:10;:12::i;:::-;-1:-1:-1;;;;;28537:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;28537:25:0;;;:34;;;;;;;;;;;:38;:50::i;24351:75::-;;;-1:-1:-1;;;;;24351:75:0;;:::o;24316:28::-;;;-1:-1:-1;;;;;24316:28:0;;:::o;26423:109::-;26476:4;26500:24;26518:4;26500:9;:24::i;:::-;26493:31;;26423:109;:::o;27457:119::-;-1:-1:-1;;;;;27550:18:0;27523:7;27550:18;;;:9;:18;;;;;;;27457:119::o;16785:148::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;16892:1:::1;16876:6:::0;;16855:40:::1;::::0;-1:-1:-1;;;;;16876:6:0;;::::1;::::0;16855:40:::1;::::0;16892:1;;16855:40:::1;16923:1;16906:19:::0;;-1:-1:-1;;;;;;16906:19:0::1;::::0;;16785:148::o;26676:135::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;26789:13:::1;::::0;26778:25:::1;::::0;:6;;:10:::1;:25::i;:::-;26753:22;:50:::0;-1:-1:-1;26676:135:0:o;16143:79::-;16181:7;16208:6;-1:-1:-1;;;;;16208:6:0;16143:79;:::o;27163:87::-;27235:7;27228:14;;;;;;;;-1:-1:-1;;27228:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27202:13;;27228:14;;27235:7;;27228:14;;27235:7;27228:14;;;;;;;;;;;;;;;;;;;;;;;;26303:108;26382:21;26303:108;:::o;28626:269::-;28719:4;28736:129;28745:12;:10;:12::i;:::-;28759:7;28768:96;28807:15;28768:96;;;;;;;;;;;;;;;;;:11;:25;28780:12;:10;:12::i;:::-;-1:-1:-1;;;;;28768:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;28768:25:0;;;:34;;;;;;;;;;;:96;:38;:96::i;27584:167::-;27662:4;27679:42;27689:12;:10;:12::i;:::-;27703:9;27714:6;27679:9;:42::i;26823:111::-;26904:22;;26823:111;:::o;26544:116::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;26621:22:::1;:31:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;26621:31:0;;::::1;::::0;;;::::1;::::0;;26544:116::o;24924:34::-;;;;;;;;;:::o;27759:143::-;-1:-1:-1;;;;;27867:18:0;;;27840:7;27867:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;27759:143::o;17088:244::-;16365:12;:10;:12::i;:::-;16355:6;;-1:-1:-1;;;;;16355:6:0;;;:22;;;16347:67;;;;;-1:-1:-1;;;16347:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;16347:67:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;17177:22:0;::::1;17169:73;;;;-1:-1:-1::0;;;17169:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17279:6;::::0;;17258:38:::1;::::0;-1:-1:-1;;;;;17258:38:0;;::::1;::::0;17279:6;::::1;::::0;17258:38:::1;::::0;::::1;17307:6;:17:::0;;-1:-1:-1;;;;;;17307:17:0::1;-1:-1:-1::0;;;;;17307:17:0;;;::::1;::::0;;;::::1;::::0;;17088:244::o;683:106::-;771:10;683:106;:::o;28907:337::-;-1:-1:-1;;;;;29000:19:0;;28992:68;;;;-1:-1:-1;;;28992:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29079:21:0;;29071:68;;;;-1:-1:-1;;;29071:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29152:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;29204:32;;;;;;;;;;;;;;;;;28907:337;;;:::o;29252:1840::-;-1:-1:-1;;;;;29349:20:0;;29341:70;;;;-1:-1:-1;;;29341:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29430:23:0;;29422:71;;;;-1:-1:-1;;;29422:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29521:1;29512:6;:10;29504:64;;;;-1:-1:-1;;;29504:64:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29592:23:0;;29610:4;29592:23;;:44;;;29629:7;:5;:7::i;:::-;-1:-1:-1;;;;;29619:17:0;:6;-1:-1:-1;;;;;29619:17:0;;29592:44;29589:1496;;;-1:-1:-1;;;;;29674:17:0;;;;;;:9;:17;;;;;;:29;;29696:6;29674:21;:29::i;:::-;-1:-1:-1;;;;;29654:17:0;;;;;;;:9;:17;;;;;;:49;;;;29741:20;;;;;;;:32;;29766:6;29741:24;:32::i;:::-;-1:-1:-1;;;;;29718:20:0;;;;;;;:9;:20;;;;;;;;;:55;;;;29793:36;;;;;;;29718:20;;29793:36;;;;;;;;;;;;;29589:1496;;;29902:3;29892:7;;:13;29889:214;;;29966:13;;29925:20;;29948:33;;-1:-1:-1;;;;;29966:13:0;29948:9;:33::i;:::-;29925:56;-1:-1:-1;30019:24:0;29925:56;30039:3;30019:19;:24::i;:::-;30009:6;:34;;30000:44;;;;;;30073:7;;:14;;30085:1;30073:11;:14::i;:::-;30063:7;:24;-1:-1:-1;29889:214:0;30135:14;;;;;;;30131:943;;;30170:42;30187:6;30195:9;30205:6;30170:16;:42::i;:::-;30131:943;;;30253:25;30281:24;30299:4;30281:9;:24::i;:::-;30376:22;;30253:52;;-1:-1:-1;30352:46:0;;;30444:21;30505:22;;30502:436;;30556:14;:21;;-1:-1:-1;;30556:21:0;;;;;30604:39;30624:18;30604:19;:39::i;:::-;30502:436;;;30708:19;:40;;;;-1:-1:-1;30732:16:0;;;;30731:17;30708:40;:71;;;;-1:-1:-1;30766:13:0;;-1:-1:-1;;;;;30766:13:0;30752:10;:27;;30708:71;:97;;;;-1:-1:-1;30783:22:0;;;;;;;30708:97;30704:234;;;30834:14;:21;;-1:-1:-1;;30834:21:0;;;;;30882:36;30897:20;30882:14;:36::i;:::-;30974:43;30991:6;30999:9;31010:6;30974:16;:43::i;:::-;-1:-1:-1;;31036:14:0;:22;;-1:-1:-1;;31036:22:0;;;-1:-1:-1;30131:943:0;29252:1840;;;:::o;5493:192::-;5579:7;5615:12;5607:6;;;;5599:29;;;;-1:-1:-1;;;5599:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;5651:5:0;;;5493:192::o;4590:181::-;4648:7;4680:5;;;4704:6;;;;4696:46;;;;;-1:-1:-1;;;4696:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;4762:1;4590:181;-1:-1:-1;;;4590:181:0:o;5944:471::-;6002:7;6247:6;6243:47;;-1:-1:-1;6277:1:0;6270:8;;6243:47;6314:5;;;6318:1;6314;:5;:1;6338:5;;;;;:10;6330:56;;;;-1:-1:-1;;;6330:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5054:136;5112:7;5139:43;5143:1;5146;5139:43;;;;;;;;;;;;;;;;;:3;:43::i;6891:132::-;6949:7;6976:39;6980:1;6983;6976:39;;;;;;;;;;;;;;;;;:3;:39::i;31110:671::-;31206:18;31227:22;31247:1;31227:15;:6;31238:3;31227:10;:15::i;:::-;:19;;:22::i;:::-;31206:43;-1:-1:-1;31260:15:0;31278;:6;31289:3;31278:10;:15::i;:::-;31260:33;-1:-1:-1;31304:19:0;31326:41;31353:13;31326:22;:6;31260:33;31326:10;:22::i;:::-;:26;;:41::i;:::-;-1:-1:-1;;;;;31408:17:0;;;;;;:9;:17;;;;;;31304:63;;-1:-1:-1;31408:29:0;;31430:6;31408:21;:29::i;:::-;-1:-1:-1;;;;;31388:17:0;;;;;;;:9;:17;;;;;;:49;;;;31471:20;;;;;;;:40;;31496:14;31471:24;:40::i;:::-;-1:-1:-1;;;;;31448:20:0;;;;;;:9;:20;;;;;;:63;;;;31567:4;31549:24;;;;:43;;31578:13;31549:28;:43::i;:::-;31540:4;31522:24;;;;:9;:24;;;;;:70;31618:12;;:28;;31635:10;31618:16;:28::i;:::-;31603:12;:43;31672:41;;;;;;;;31698:1;;-1:-1:-1;;;;;31672:41:0;;;;;;;;;;;;31747:9;-1:-1:-1;;;;;31729:44:0;31739:6;-1:-1:-1;;;;;31729:44:0;;31758:14;31729:44;;;;;;;;;;;;;;;;;;31110:671;;;;;;:::o;33015:421::-;33103:16;;;33117:1;33103:16;;;;;;;;33079:21;;33103:16;;;;;;;;-1:-1:-1;;33140:15:0;;:22;;;-1:-1:-1;;;33140:22:0;;;;33079:40;;-1:-1:-1;;;;;;33140:15:0;;;;:20;;-1:-1:-1;33140:22:0;;;;;;;;;;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;33140:22:0;33130:7;;:4;;33135:1;;33130:7;;;;-1:-1:-1;;;;;33130:32:0;;;:7;;;;;;;;;:32;33191:11;;33173:7;;33191:11;;;33173:4;;33191:11;;33173:7;;;;;;-1:-1:-1;;;;;33173:30:0;;;:7;;;;;;;;;:30;33248:15;;33216:60;;33233:4;;33248:15;33266:9;33216:8;:60::i;:::-;33287:15;;33395;;33287:141;;-1:-1:-1;;;33287:141:0;;;;;;;;-1:-1:-1;;;;;33395:15:0;;;33287:141;;;;;;33412:15;33287:141;;;;;;;;;;;;;;;;;;;;;:15;;;;;:66;;33361:9;;;;33382:4;;33395:15;33412;33287:141;;;;;;;;;;;;;;;;:15;:141;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33015:421;;:::o;31793:717::-;31864:20;31887:34;31919:1;31887:27;:20;31912:1;31887:24;:27::i;:34::-;31864:57;-1:-1:-1;31932:17:0;31952:41;:20;31864:57;31952:24;:41::i;:::-;31932:61;-1:-1:-1;32036:21:0;32078:33;32095:15;32078:16;:33::i;:::-;32132:18;32153:41;:21;32179:14;32153:25;:41::i;:::-;32132:62;-1:-1:-1;32205:17:0;32225:24;32247:1;32225:17;32132:62;32240:1;32225:14;:17::i;:24::-;32337:9;;32321:49;;32205:44;;-1:-1:-1;32205:44:0;;-1:-1:-1;;;;;32337:9:0;;;;32321:49;;;;;32205:44;;32260:16;32321:49;32260:16;32321:49;32205:44;32337:9;32321:49;;;;;;;;;;;;;;;;;;;;;32381:40;32394:12;32408;32381;:40::i;:::-;32447:55;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31793:717;;;;;;;:::o;7519:278::-;7605:7;7640:12;7633:5;7625:28;;;;-1:-1:-1;;;7625:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7664:9;7680:1;7676;:5;;;;;;;7519:278;-1:-1:-1;;;;;7519:278:0:o;32522:481::-;32672:16;;;32686:1;32672:16;;;;;;;;32648:21;;32672:16;;;;;;;;;;-1:-1:-1;32672:16:0;32648:40;;32717:4;32699;32704:1;32699:7;;;;;;;;-1:-1:-1;;;;;32699:23:0;;;:7;;;;;;;;;;:23;;;;32743:15;;:22;;;-1:-1:-1;;;32743:22:0;;;;:15;;;;;:20;;:22;;;;;32699:7;;32743:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;32743:22:0;32733:7;;:4;;32738:1;;32733:7;;;;;;-1:-1:-1;;;;;32733:32:0;;;:7;;;;;;;;;:32;32810:15;;32778:62;;32795:4;;32810:15;32828:11;32778:8;:62::i;:::-;32879:15;;:116;;-1:-1:-1;;;32879:116:0;;;;;;;;:15;:116;;;;;;32973:4;32879:116;;;;;;32979:15;32879:116;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32879:15:0;;;;:66;;32946:11;;32960:4;;32973;32979:15;32879:116;;;;;;;;;;;;;;;;:15;:116;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32522:481;;:::o;33444:382::-;33624:15;;33592:62;;33609:4;;-1:-1:-1;;;;;33624:15:0;33642:11;33592:8;:62::i;:::-;33697:15;;33785;;33697:121;;;-1:-1:-1;;;33697:121:0;;33755:4;33697:121;;;;;;;;;;:15;:121;;;;;;;;;;-1:-1:-1;;;;;33785:15:0;;;33697:121;;;;33802:15;33697:121;;;;;;:15;;;;;:31;;33736:9;;33697:121;;;;;;;;;;;;;;;33736:9;33697:15;:121;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;33444:382:0:o
Swarm Source
ipfs://4a66efcf8f19cb825faf6b2449e76171f1e7376017896bc73d3237cd51a53159
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.