ETH Price: $3,458.54 (+3.73%)
 

Overview

Max Total Supply

1,000,000,000 PLEDGE

Holders

1,710

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0 PLEDGE

Value
$0.00
0xffd3c15c2f325bac390b1c7dd5d494fd7d2ef76b
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
PLEDGE

Compiler Version
v0.8.28+commit.7893614a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 21 : pledge.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
/*
    
.. ..
:. :;:::;;:;::.. .
.:. .;xxxxXXXXx+;:.. .
. . :;X$&&$&&$$$X+;::... ...
. ..:+xX$x:.....:+XXx++;::...........:.
.+++++xX$X+. .+XX++;;:::::...:;;:.......... .
. . .+$&&&&x:. .;Xx++;;;;::;;+++;;:::..:::...... .
. . . . . :::;:... :xXXx++;+++xXx;+;..... . .
. .. . . ... .. . .. ... ... ....:X$XXxxxXXXXxx+x++;;;::............ .
.. ......... .. .......... .... . . ...:...:X$$X$Xx+;;;;:...... ... ...... . ..
.........:......... . ....... . .:;:.....$$X;. ..;;;;;;;;;;;;:::..:......
.....::::;;:;+.;:.:... ...::::.. . ... . . ...:::.. ...; .+xx++;+;+;+;;;;;;:;:::...
..:..:+;;++;x++Xxxxxx++x;::... ::;;;:;......... . .... ...:;;::.. ... .;++xx++++xx+x++x++++;:..
..::.;;+;++xx+XXX$XXXX$$$&&&$$$$$Xx::;++++;:;............. .:;;;;::...:xx;:.... .;::::xXXXXXXXX$$$$$$$$XXxx;+:.
. :::;;+x+xXXXXXX$$$$$$$$$$$$&$$$$$&&$$$X+++;:......... ...... .+xxXxx::..;XX+;.......+x+$$$$$$Xx;:
..:;;;xXXX$$$&&$$XxxXxxxx+++;;+++++x$&&$Xx+;;;.....:......... .:+xxxx;;:..+$Xx+::....;X$$.
;&$+;;X&$x+;;:..:::::;....:.. .+xxx++::...;$&Xx+;:..+;
x$x. +&&$XXx;;:;::;+;..:;;++;:;+x$x++;;....;$&$XXXXXX.
+$;;:;X$+ .xXxxxx+++;..;xX$$X+;x$$x;+;;::.:;$&$$$$$;
x$$$$X;...;$$+. ;Xx+..;xXXxx++x$$Xx++;;:::+$$$$x.
;X$X$XX$Xx+;:;;x$$XXx$$Xxx+++x$$XXx+++;::.
;XX&&&&xxXX$$$&$+:;X$&$Xxx+++x$&$Xx+;:::
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 2 of 21 : Ownable.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol)
pragma solidity ^0.8.20;
import {Context} from "../utils/Context.sol";
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* The initial owner is set to the address provided by the deployer. This can
* later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
/**
* @dev The caller account is not authorized to perform an operation.
*/
error OwnableUnauthorizedAccount(address account);
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 3 of 21 : ERC20Permit.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/extensions/ERC20Permit.sol)
pragma solidity ^0.8.20;
import {IERC20Permit} from "./IERC20Permit.sol";
import {ERC20} from "../ERC20.sol";
import {ECDSA} from "../../../utils/cryptography/ECDSA.sol";
import {EIP712} from "../../../utils/cryptography/EIP712.sol";
import {Nonces} from "../../../utils/Nonces.sol";
/**
* @dev Implementation of the ERC-20 Permit extension allowing approvals to be made via signatures, as defined in
* https://eips.ethereum.org/EIPS/eip-2612[ERC-2612].
*
* Adds the {permit} method, which can be used to change an account's ERC-20 allowance (see {IERC20-allowance}) by
* presenting a message signed by the account. By not relying on `{IERC20-approve}`, the token holder account doesn't
* need to send a transaction, and thus is not required to hold Ether at all.
*/
abstract contract ERC20Permit is ERC20, IERC20Permit, EIP712, Nonces {
bytes32 private constant PERMIT_TYPEHASH =
keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
/**
* @dev Permit deadline has expired.
*/
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 4 of 21 : ERC20.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/ERC20.sol)
pragma solidity ^0.8.20;
import {IERC20} from "./IERC20.sol";
import {IERC20Metadata} from "./extensions/IERC20Metadata.sol";
import {Context} from "../../utils/Context.sol";
import {IERC20Errors} from "../../interfaces/draft-IERC6093.sol";
/**
* @dev Implementation of the {IERC20} interface.
*
* This implementation is agnostic to the way tokens are created. This means
* that a supply mechanism has to be added in a derived contract using {_mint}.
*
* TIP: For a detailed writeup see our guide
* https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
* to implement supply mechanisms].
*
* The default value of {decimals} is 18. To change this, you should override
* this function so it returns a different value.
*
* We have followed general OpenZeppelin Contracts guidelines: functions revert
* instead returning `false` on failure. This behavior is nonetheless
* conventional and does not conflict with the expectations of ERC-20
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 5 of 21 : Nonces.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.0) (utils/Nonces.sol)
pragma solidity ^0.8.20;
/**
* @dev Provides tracking nonces for addresses. Nonces will only increment.
*/
abstract contract Nonces {
/**
* @dev The nonce used for an `account` is not the expected current nonce.
*/
error InvalidAccountNonce(address account, uint256 currentNonce);
mapping(address account => uint256) private _nonces;
/**
* @dev Returns the next unused nonce for an address.
*/
function nonces(address owner) public view virtual returns (uint256) {
return _nonces[owner];
}
/**
* @dev Consumes a nonce.
*
* Returns the current value and increments nonce.
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 6 of 21 : EIP712.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/cryptography/EIP712.sol)
pragma solidity ^0.8.20;
import {MessageHashUtils} from "./MessageHashUtils.sol";
import {ShortStrings, ShortString} from "../ShortStrings.sol";
import {IERC5267} from "../../interfaces/IERC5267.sol";
/**
* @dev https://eips.ethereum.org/EIPS/eip-712[EIP-712] is a standard for hashing and signing of typed structured data.
*
* The encoding scheme specified in the EIP requires a domain separator and a hash of the typed structured data, whose
* encoding is very generic and therefore its implementation in Solidity is not feasible, thus this contract
* does not implement the encoding itself. Protocols need to implement the type-specific encoding they need in order to
* produce the hash of their typed data using a combination of `abi.encode` and `keccak256`.
*
* This contract implements the EIP-712 domain separator ({_domainSeparatorV4}) that is used as part of the encoding
* scheme, and the final step of the encoding to obtain the message digest that is then signed via ECDSA
* ({_hashTypedDataV4}).
*
* The implementation of the domain separator was designed to be as efficient as possible while still properly updating
* the chain id to protect against replay attacks on an eventual fork of the chain.
*
* NOTE: This contract implements the version of the encoding known as "v4", as implemented by the JSON RPC method
* https://docs.metamask.io/guide/signing-data.html[`eth_signTypedDataV4` in MetaMask].
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 7 of 21 : ECDSA.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/cryptography/ECDSA.sol)
pragma solidity ^0.8.20;
/**
* @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.
*
* These functions can be used to verify that a message was signed by the holder
* of the private keys of a given address.
*/
library ECDSA {
enum RecoverError {
NoError,
InvalidSignature,
InvalidSignatureLength,
InvalidSignatureS
}
/**
* @dev The signature derives the `address(0)`.
*/
error ECDSAInvalidSignature();
/**
* @dev The signature has an invalid length.
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 8 of 21 : IERC20Permit.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/extensions/IERC20Permit.sol)
pragma solidity ^0.8.20;
/**
* @dev Interface of the ERC-20 Permit extension allowing approvals to be made via signatures, as defined in
* https://eips.ethereum.org/EIPS/eip-2612[ERC-2612].
*
* Adds the {permit} method, which can be used to change an account's ERC-20 allowance (see {IERC20-allowance}) by
* presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't
* need to send a transaction, and thus is not required to hold Ether at all.
*
* ==== Security Considerations
*
* There are two important considerations concerning the use of `permit`. The first is that a valid permit signature
* expresses an allowance, and it should not be assumed to convey additional meaning. In particular, it should not be
* considered as an intention to spend the allowance in any specific way. The second is that because permits have
* built-in replay protection and can be submitted by anyone, they can be frontrun. A protocol that uses permits should
* take this into consideration and allow a `permit` call to fail. Combining these two aspects, a pattern that may be
* generally recommended is:
*
* ```solidity
* function doThingWithPermit(..., uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s) public {
* try token.permit(msg.sender, address(this), value, deadline, v, r, s) {} catch {}
* doThing(..., value);
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 9 of 21 : draft-IERC6093.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (interfaces/draft-IERC6093.sol)
pragma solidity ^0.8.20;
/**
* @dev Standard ERC-20 Errors
* Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC-20 tokens.
*/
interface IERC20Errors {
/**
* @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers.
* @param sender Address whose tokens are being transferred.
* @param balance Current balance for the interacting account.
* @param needed Minimum amount required to perform a transfer.
*/
error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed);
/**
* @dev Indicates a failure with the token `sender`. Used in transfers.
* @param sender Address whose tokens are being transferred.
*/
error ERC20InvalidSender(address sender);
/**
* @dev Indicates a failure with the token `receiver`. Used in transfers.
* @param receiver Address to which tokens are being transferred.
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 10 of 21 : Context.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol)
pragma solidity ^0.8.20;
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
function _contextSuffixLength() internal view virtual returns (uint256) {
return 0;
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 11 of 21 : IERC20Metadata.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/extensions/IERC20Metadata.sol)
pragma solidity ^0.8.20;
import {IERC20} from "../IERC20.sol";
/**
* @dev Interface for the optional metadata functions from the ERC-20 standard.
*/
interface IERC20Metadata is IERC20 {
/**
* @dev Returns the name of the token.
*/
function name() external view returns (string memory);
/**
* @dev Returns the symbol of the token.
*/
function symbol() external view returns (string memory);
/**
* @dev Returns the decimals places of the token.
*/
function decimals() external view returns (uint8);
}
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 12 of 21 : IERC20.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/IERC20.sol)
pragma solidity ^0.8.20;
/**
* @dev Interface of the ERC-20 standard as defined in the ERC.
*/
interface IERC20 {
/**
* @dev Emitted when `value` tokens are moved from one account (`from`) to
* another (`to`).
*
* Note that `value` may be zero.
*/
event Transfer(address indexed from, address indexed to, uint256 value);
/**
* @dev Emitted when the allowance of a `spender` for an `owner` is set by
* a call to {approve}. `value` is the new allowance.
*/
event Approval(address indexed owner, address indexed spender, uint256 value);
/**
* @dev Returns the value of tokens in existence.
*/
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 13 of 21 : IERC5267.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.0) (interfaces/IERC5267.sol)
pragma solidity ^0.8.20;
interface IERC5267 {
/**
* @dev MAY be emitted to signal that the domain could have changed.
*/
event EIP712DomainChanged();
/**
* @dev returns the fields and values that describe the domain separator used by this contract for EIP-712
* signature.
*/
function eip712Domain()
external
view
returns (
bytes1 fields,
string memory name,
string memory version,
uint256 chainId,
address verifyingContract,
bytes32 salt,
uint256[] memory extensions
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 14 of 21 : ShortStrings.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/ShortStrings.sol)
pragma solidity ^0.8.20;
import {StorageSlot} from "./StorageSlot.sol";
// | string | 0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA |
// | length | 0x BB |
type ShortString is bytes32;
/**
* @dev This library provides functions to convert short memory strings
* into a `ShortString` type that can be used as an immutable variable.
*
* Strings of arbitrary length can be optimized using this library if
* they are short enough (up to 31 bytes) by packing them with their
* length (1 byte) in a single EVM word (32 bytes). Additionally, a
* fallback mechanism can be used for every other case.
*
* Usage example:
*
* ```solidity
* contract Named {
* using ShortStrings for *;
*
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 15 of 21 : MessageHashUtils.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/cryptography/MessageHashUtils.sol)
pragma solidity ^0.8.20;
import {Strings} from "../Strings.sol";
/**
* @dev Signature message hash utilities for producing digests to be consumed by {ECDSA} recovery or signing.
*
* The library provides methods for generating a hash of a message that conforms to the
* https://eips.ethereum.org/EIPS/eip-191[ERC-191] and https://eips.ethereum.org/EIPS/eip-712[EIP 712]
* specifications.
*/
library MessageHashUtils {
/**
* @dev Returns the keccak256 digest of an ERC-191 signed data with version
* `0x45` (`personal_sign` messages).
*
* The digest is calculated by prefixing a bytes32 `messageHash` with
* `"\x19Ethereum Signed Message:\n32"` and hashing the result. It corresponds with the
* hash signed when using the https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`] JSON-RPC method.
*
* NOTE: The `messageHash` parameter is intended to be the result of hashing a raw message with
* keccak256, although any bytes32 value can be safely used because the final digest will
* be re-hashed.
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 16 of 21 : Strings.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/Strings.sol)
pragma solidity ^0.8.20;
import {Math} from "./math/Math.sol";
import {SignedMath} from "./math/SignedMath.sol";
/**
* @dev String operations.
*/
library Strings {
bytes16 private constant HEX_DIGITS = "0123456789abcdef";
uint8 private constant ADDRESS_LENGTH = 20;
/**
* @dev The `value` string doesn't fit in the specified `length`.
*/
error StringsInsufficientHexLength(uint256 value, uint256 length);
/**
* @dev Converts a `uint256` to its ASCII `string` decimal representation.
*/
function toString(uint256 value) internal pure returns (string memory) {
unchecked {
uint256 length = Math.log10(value) + 1;
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 17 of 21 : StorageSlot.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/StorageSlot.sol)
// This file was procedurally generated from scripts/generate/templates/StorageSlot.js.
pragma solidity ^0.8.20;
/**
* @dev Library for reading and writing primitive types to specific storage slots.
*
* Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.
* This library helps with reading and writing to such slots without the need for inline assembly.
*
* The functions in this library return Slot structs that contain a `value` member that can be used to read or write.
*
* Example usage to set ERC-1967 implementation slot:
* ```solidity
* contract ERC1967 {
* // Define the slot. Alternatively, use the SlotDerivation library to derive the slot.
* bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;
*
* function _getImplementation() internal view returns (address) {
* return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;
* }
*
* function _setImplementation(address newImplementation) internal {
* require(newImplementation.code.length > 0);
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 18 of 21 : SignedMath.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/math/SignedMath.sol)
pragma solidity ^0.8.20;
import {SafeCast} from "./SafeCast.sol";
/**
* @dev Standard signed math utilities missing in the Solidity language.
*/
library SignedMath {
/**
* @dev Branchless ternary evaluation for `a ? b : c`. Gas costs are constant.
*
* IMPORTANT: This function may reduce bytecode size and consume less gas when used standalone.
* However, the compiler may optimize Solidity ternary operations (i.e. `a ? b : c`) to only compute
* one branch when needed, making this function more expensive.
*/
function ternary(bool condition, int256 a, int256 b) internal pure returns (int256) {
unchecked {
// branchless ternary works because:
// b ^ (a ^ b) == a
// b ^ 0 == b
return b ^ ((a ^ b) * int256(SafeCast.toUint(condition)));
}
}
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 19 of 21 : Math.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/math/Math.sol)
pragma solidity ^0.8.20;
import {Panic} from "../Panic.sol";
import {SafeCast} from "./SafeCast.sol";
/**
* @dev Standard math utilities missing in the Solidity language.
*/
library Math {
enum Rounding {
Floor, // Toward negative infinity
Ceil, // Toward positive infinity
Trunc, // Toward zero
Expand // Away from zero
}
/**
* @dev Returns the addition of two unsigned integers, with an success flag (no overflow).
*/
function tryAdd(uint256 a, uint256 b) internal pure returns (bool success, uint256 result) {
unchecked {
uint256 c = a + b;
if (c < a) return (false, 0);
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 20 of 21 : SafeCast.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/math/SafeCast.sol)
// This file was procedurally generated from scripts/generate/templates/SafeCast.js.
pragma solidity ^0.8.20;
/**
* @dev Wrappers over Solidity's uintXX/intXX/bool casting operators with added overflow
* checks.
*
* Downcasting from uint256/int256 in Solidity does not revert on overflow. This can
* easily result in undesired exploitation or bugs, since developers usually
* assume that overflows raise errors. `SafeCast` restores this intuition by
* reverting the transaction when such 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 SafeCast {
/**
* @dev Value doesn't fit in an uint of `bits` size.
*/
error SafeCastOverflowedUintDowncast(uint8 bits, uint256 value);
/**
* @dev An int value doesn't fit in an uint of `bits` size.
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

File 21 of 21 : Panic.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.1.0) (utils/Panic.sol)
pragma solidity ^0.8.20;
/**
* @dev Helper library for emitting standardized panic codes.
*
* ```solidity
* contract Example {
* using Panic for uint256;
*
* // Use any of the declared internal constants
* function foo() { Panic.GENERIC.panic(); }
*
* // Alternatively
* function foo() { Panic.panic(Panic.GENERIC); }
* }
* ```
*
* Follows the list from https://github.com/ethereum/solidity/blob/v0.8.24/libsolutil/ErrorCodes.h[libsolutil].
*
* _Available since v5.1._
*/
// slither-disable-next-line unused-state
library Panic {
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Settings
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
"optimizer": {
"enabled": true,
"runs": 200
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
},
"remappings": []
}
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ECDSAInvalidSignature","type":"error"},{"inputs":[{"internalType":"uint256","name":"length","type":"uint256"}],"name":"ECDSAInvalidSignatureLength","type":"error"},{"inputs":[{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"ECDSAInvalidSignatureS","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"inputs":[{"internalType":"uint256","name":"deadline","type":"uint256"}],"name":"ERC2612ExpiredSignature","type":"error"},{"inputs":[{"internalType":"address","name":"signer","type":"address"},{"internalType":"address","name":"owner","type":"address"}],"name":"ERC2612InvalidSigner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"currentNonce","type":"uint256"}],"name":"InvalidAccountNonce","type":"error"},{"inputs":[],"name":"InvalidShortString","type":"error"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"inputs":[{"internalType":"string","name":"str","type":"string"}],"name":"StringTooLong","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":true,"internalType":"address","name":"pledgerAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"transferredAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"allowedTransferAmount","type":"uint256"}],"name":"BrokenPledge","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pledgerAddress","type":"address"}],"name":"CompletedPledge","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pledgerAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"pledgerBalance","type":"uint256"}],"name":"CreatedPledge","type":"event"},{"anonymous":false,"inputs":[],"name":"EIP712DomainChanged","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":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"attemptedAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"adjustedAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"penalty","type":"uint256"}],"name":"PenaltyCharged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"},{"indexed":false,"internalType":"address","name":"feeRecipient","type":"address"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"ProtectionsToggled","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":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PROTECTION_PERIOD","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_addresses","type":"address[]"}],"name":"airdropToPledgers","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":"value","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":[{"internalType":"address","name":"_feeReceiver","type":"address"}],"name":"beginLaunchProtection","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"completePledge","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"defaultPledgeOnePercent","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"disableLaunchProtection","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"eip712Domain","outputs":[{"internalType":"bytes1","name":"fields","type":"bytes1"},{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"version","type":"string"},{"internalType":"uint256","name":"chainId","type":"uint256"},{"internalType":"address","name":"verifyingContract","type":"address"},{"internalType":"bytes32","name":"salt","type":"bytes32"},{"internalType":"uint256[]","name":"extensions","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeReceiver","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"getPledgedBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"getPledgerData","outputs":[{"internalType":"uint8","name":"","type":"uint8"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"getTimeRemainingInWindow","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"getTransferableAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTokenSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nonAirdropTokensMinted","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"pledge","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"pledgeAirdropAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"pledger","outputs":[{"internalType":"uint8","name":"status","type":"uint8"},{"internalType":"uint256","name":"onePercent","type":"uint256"},{"internalType":"uint256","name":"monthlyWindowStart","type":"uint256"},{"internalType":"uint256","name":"amountTransferredThisWindow","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"protectionStartTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"protectionsEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_limitDivisor","type":"uint256"}],"name":"setLimitDivisor","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_uniswapRouterAddress","type":"address"}],"name":"setUniswapRouterAddress","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":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","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":"uniswapRouterAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"}]

610160604052600a80546001600160a01b031916733fc91a3afd70395cd496c647d5a6cc9d4b2b7fad179055610033601290565b61003e90600a6103c3565b61004c90633b9aca006103d8565b600d556103e8600d5461005f91906103ef565b600e556064600e5461007191906103ef565b600f55600a601055348015610084575f5ffd5b503360405180604001604052806006815260200165504c4544474560d01b81525080604051806040016040528060018152602001603160f81b81525060405180604001604052806006815260200165504c4544474560d01b81525060405180604001604052806006815260200165504c4544474560d01b815250816003908161010d91906104a6565b50600461011a82826104a6565b5061012a9150839050600561020c565b6101205261013981600661020c565b61014052815160208084019190912060e052815190820120610100524660a0526101c560e05161010051604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f60208201529081019290925260608201524660808201523060a08201525f9060c00160405160208183030381529060405280519060200120905090565b60805250503060c052506001600160a01b0381166101fd57604051631e4fbdf760e01b81525f60048201526024015b60405180910390fd5b6102068161023e565b506105b8565b5f602083511015610227576102208361028f565b9050610238565b8161023284826104a6565b5060ff90505b92915050565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b5f5f829050601f815111156102b9578260405163305a27a960e01b81526004016101f49190610560565b80516102c482610595565b179392505050565b634e487b7160e01b5f52601160045260245ffd5b6001815b600184111561031b578085048111156102ff576102ff6102cc565b600184161561030d57908102905b60019390931c9280026102e4565b935093915050565b5f8261033157506001610238565b8161033d57505f610238565b8160018114610353576002811461035d57610379565b6001915050610238565b60ff84111561036e5761036e6102cc565b50506001821b610238565b5060208310610133831016604e8410600b841016171561039c575081810a610238565b6103a85f1984846102e0565b805f19048211156103bb576103bb6102cc565b029392505050565b5f6103d160ff841683610323565b9392505050565b8082028115828204841417610238576102386102cc565b5f8261040957634e487b7160e01b5f52601260045260245ffd5b500490565b634e487b7160e01b5f52604160045260245ffd5b600181811c9082168061043657607f821691505b60208210810361045457634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156104a157805f5260205f20601f840160051c8101602085101561047f5750805b601f840160051c820191505b8181101561049e575f815560010161048b565b50505b505050565b81516001600160401b038111156104bf576104bf61040e565b6104d3816104cd8454610422565b8461045a565b6020601f821160018114610505575f83156104ee5750848201515b5f19600385901b1c1916600184901b17845561049e565b5f84815260208120601f198516915b828110156105345787850151825560209485019460019092019101610514565b508482101561055157868401515f19600387901b60f8161c191681555b50505050600190811b01905550565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80516020808301519190811015610454575f1960209190910360031b1b16919050565b60805160a05160c05160e0516101005161012051610140516120e16106095f395f61149e01525f61147101525f61136401525f61133c01525f61129701525f6112c101525f6112eb01526120e15ff3fe608060405234801561000f575f5ffd5b5060043610610228575f3560e01c80638da5cb5b1161012a578063c1361d3b116100b4578063db15d18511610079578063db15d185146104c1578063dd62ed3e146104d4578063ea6270001461050c578063f2fde38b14610514578063f9e19aed14610527575f5ffd5b8063c1361d3b14610423578063ca86f96a1461042c578063cfe7f8581461043f578063d505accf14610452578063dadb40d914610465575f5ffd5b8063a4ef49c4116100fa578063a4ef49c4146103d9578063a6091aaa146103e1578063a9059cbb146103ea578063b1059d8b146103fd578063b3f0067414610410575f5ffd5b80638da5cb5b1461039957806391e12d8d146103aa57806395d89b41146103be578063a3c958e0146103c6575f5ffd5b8063331babd7116101b6578063715018a61161017b578063715018a6146103525780637ecebe001461035a57806384b0196e1461036d57806388ffe867146103885780638a161a3314610390575f5ffd5b8063331babd7146102f15780633644e5151461030457806340c10f191461030c57806350f7c2041461032157806370a082311461032a575f5ffd5b806318160ddd116101fc57806318160ddd1461029357806320ca3c7f1461029b57806323b872dd146102c6578063265c82eb146102d9578063313ce567146102e2575f5ffd5b8062b61dd91461022c57806306950d1c1461025257806306fdde031461025b578063095ea7b314610270575b5f5ffd5b61023f61023a366004611d5d565b61056b565b6040519081526020015b60405180910390f35b61023f611d4c81565b610263610643565b6040516102499190611dab565b61028361027e366004611dbd565b6106d3565b6040519015158152602001610249565b60025461023f565b600a546102ae906001600160a01b031681565b6040516001600160a01b039091168152602001610249565b6102836102d4366004611de5565b6106ec565b61023f600c5481565b60405160128152602001610249565b61023f6102ff366004611d5d565b61070f565b61023f610765565b61031f61031a366004611dbd565b610773565b005b61023f600d5481565b61023f610338366004611d5d565b6001600160a01b03165f9081526020819052604090205490565b61031f6108be565b61023f610368366004611d5d565b6108d1565b6103756108ee565b6040516102499796959493929190611e1f565b61031f610930565b61023f600f5481565b6008546001600160a01b03166102ae565b60085461028390600160a01b900460ff1681565b610263610aaa565b61031f6103d4366004611eb5565b610ab9565b61031f610b07565b61023f600b5481565b6102836103f8366004611dbd565b610b78565b61031f61040b366004611ecc565b610b85565b6009546102ae906001600160a01b031681565b61023f600e5481565b61031f61043a366004611d5d565b610d8a565b61023f61044d366004611d5d565b610e1c565b61031f610460366004611f3d565b610e64565b61049d610473366004611d5d565b60116020525f9081526040902080546001820154600283015460039093015460ff90921692909184565b6040805160ff90951685526020850193909352918301526060820152608001610249565b61031f6104cf366004611d5d565b610f9a565b61023f6104e2366004611faa565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b61031f610fc4565b61031f610522366004611d5d565b6110be565b61053a610535366004611d5d565b6110fb565b6040805160ff90971687526020870195909552938501929092526060840152608083015260a082015260c001610249565b6001600160a01b0381165f9081526011602052604081205460ff16600103610637576001600160a01b0382165f908152601160205260408120600101548082036105b45750600f545b6105bd84611175565b156105ca578091506105f2565b6001600160a01b0384165f908152601160205260409020600301546105ef9082611fef565b91505b6001600160a01b0384165f908152602081905260409020548211610616578161062f565b6001600160a01b0384165f908152602081905260409020545b949350505050565b505f919050565b919050565b60606003805461065290612002565b80601f016020809104026020016040519081016040528092919081815260200182805461067e90612002565b80156106c95780601f106106a0576101008083540402835291602001916106c9565b820191905f5260205f20905b8154815290600101906020018083116106ac57829003601f168201915b5050505050905090565b5f336106e08185856111a7565b60019150505b92915050565b5f336106f98582856111b9565b61070485858561122e565b506001949350505050565b6001600160a01b0381165f9081526011602052604081205460ff16600103610637576001600160a01b0382165f90815260116020526040812060010154908190036107595750600f545b5f61062f82606461203a565b5f61076e61128b565b905090565b61077b6113b4565b600a600d5461078a9190612051565b81600b546107989190612070565b11156107fa5760405162461bcd60e51b815260206004820152602660248201527f313025204d415820535550504c59204e4f4e2d41495244524f50204341502052604482015265115050d2115160d21b60648201526084015b60405180910390fd5b5f811180156108175750600d546002546108149083612070565b11155b6108525760405162461bcd60e51b815260206004820152600c60248201526b15d493d391c8105353d5539560a21b60448201526064016107f1565b6001600160a01b03821661089a5760405162461bcd60e51b815260206004820152600f60248201526e494e56414c4944204144445245535360881b60448201526064016107f1565b6108a482826113e1565b80600b5f8282546108b59190612070565b90915550505050565b6108c66113b4565b6108cf5f611419565b565b6001600160a01b0381165f908152600760205260408120546106e6565b5f6060805f5f5f60606108ff61146a565b610907611497565b604080515f80825260208201909252600f60f81b9b939a50919850469750309650945092509050565b335f818152602081815260408083205460119092529091205460ff1660020361098f5760405162461bcd60e51b8152602060048201526011602482015270484153204641494c454420504c4544474560781b60448201526064016107f1565b60648110156109e05760405162461bcd60e51b815260206004820152601a60248201527f4d555354204f574e203e3d20313030204241534520554e49545300000000000060448201526064016107f1565b5f6109ea8361070f565b905080821015610a335760405162461bcd60e51b815260206004820152601460248201527343414e4e4f542052454455434520504c4544474560601b60448201526064016107f1565b610a3e606483612051565b6001600160a01b0384165f8181526011602052604090819020600180820194909455805460ff191690931790925590517f8befdfb767f1fa8afaab1250205358276a8dfd21b2d744e0c068ec9ce67f70e290610a9d9085815260200190565b60405180910390a2505050565b60606004805461065290612002565b610ac16113b4565b5f8111610b025760405162461bcd60e51b815260206004820152600f60248201526e24a72b20a624a22fa224ab24a9a7a960891b60448201526064016107f1565b601055565b610b0f6113b4565b6008805460ff60a01b19169081905560095460408051600160a01b90930460ff16151583526001600160a01b03909116602083015242908201527f2e38c7ebc623cd6558435b9be0c24407b17e2981956d8082c95231e8713113de9060600160405180910390a1565b5f336106e081858561122e565b610b8d6113b4565b600d548190606490610ba090605a61203a565b610baa9190612051565b600e54610bb7908361203a565b600b54600254610bc79190611fef565b610bd19190612070565b1115610c2a5760405162461bcd60e51b815260206004820152602260248201527f393025204d415820535550504c592041495244524f5020434150205245414348604482015261115160f21b60648201526084016107f1565b5f5b81811015610d845760115f858584818110610c4957610c49612083565b9050602002016020810190610c5e9190611d5d565b6001600160a01b0316815260208101919091526040015f205460ff16158015610cb657505f848483818110610c9557610c95612083565b9050602002016020810190610caa9190611d5d565b6001600160a01b031614155b610cf45760405162461bcd60e51b815260206004820152600f60248201526e24a72b20a624a210282622a223a2a960891b60448201526064016107f1565b610d26848483818110610d0957610d09612083565b9050602002016020810190610d1e9190611d5d565b600e546113e1565b600160115f868685818110610d3d57610d3d612083565b9050602002016020810190610d529190611d5d565b6001600160a01b0316815260208101919091526040015f20805460ff191660ff92909216919091179055600101610c2c565b50505050565b610d926113b4565b600980546001600160a01b0383166001600160a01b031990911681179091556008805460ff60a01b1916600160a01b9081179182905542600c819055604080519290930460ff16151582526020820193909352908101919091527f2e38c7ebc623cd6558435b9be0c24407b17e2981956d8082c95231e8713113de9060600160405180910390a150565b5f610e2682611175565b15610e3257505f919050565b6001600160a01b0382165f90815260116020526040902060020154610e579042611fef565b6106e69062278d00611fef565b83421115610e885760405163313c898160e11b8152600481018590526024016107f1565b5f7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9888888610ed38c6001600160a01b03165f90815260076020526040902080546001810190915590565b6040805160208101969096526001600160a01b0394851690860152929091166060840152608083015260a082015260c0810186905260e0016040516020818303038152906040528051906020012090505f610f2d826114c4565b90505f610f3c828787876114f0565b9050896001600160a01b0316816001600160a01b031614610f83576040516325c0072360e11b81526001600160a01b0380831660048301528b1660248201526044016107f1565b610f8e8a8a8a6111a7565b50505050505050505050565b610fa26113b4565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b335f8181526011602052604090205460ff166001146110185760405162461bcd60e51b815260206004820152601060248201526f4e4f2041435449564520504c4544474560801b60448201526064016107f1565b6001600160a01b0381165f90815260208190526040902054156110735760405162461bcd60e51b81526020600482015260136024820152724d555354204841564520302042414c414e434560681b60448201526064016107f1565b6001600160a01b0381165f81815260116020526040808220805460ff19166003179055517f5db4685c003ecba127ab382661505e1ea89db4bf387b04ce97d1d15874a03a529190a250565b6110c66113b4565b6001600160a01b0381166110ef57604051631e4fbdf760e01b81525f60048201526024016107f1565b6110f881611419565b50565b6001600160a01b0381165f90815260116020908152604080832054918390528220548291829182918291829160ff16906111348961070f565b6001600160a01b038a165f908152601160205260409020600301546111588b61056b565b6111618c610e1c565b949c939b5091995097509550909350915050565b6001600160a01b0381165f9081526011602052604081206002015462278d009061119f9042611fef565b101592915050565b6111b4838383600161151c565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198114610d84578181101561122057604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064016107f1565b610d8484848484035f61151c565b6001600160a01b03831661125757604051634b637e8f60e11b81525f60048201526024016107f1565b6001600160a01b0382166112805760405163ec442f0560e01b81525f60048201526024016107f1565b6111b48383836115ee565b5f306001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000161480156112e357507f000000000000000000000000000000000000000000000000000000000000000046145b1561130d57507f000000000000000000000000000000000000000000000000000000000000000090565b61076e604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f60208201527f0000000000000000000000000000000000000000000000000000000000000000918101919091527f000000000000000000000000000000000000000000000000000000000000000060608201524660808201523060a08201525f9060c00160405160208183030381529060405280519060200120905090565b6008546001600160a01b031633146108cf5760405163118cdaa760e01b81523360048201526024016107f1565b6001600160a01b03821661140a5760405163ec442f0560e01b81525f60048201526024016107f1565b6114155f83836115ee565b5050565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b606061076e7f000000000000000000000000000000000000000000000000000000000000000060056117bf565b606061076e7f000000000000000000000000000000000000000000000000000000000000000060066117bf565b5f6106e66114d061128b565b8360405161190160f01b8152600281019290925260228201526042902090565b5f5f5f5f61150088888888611868565b9250925092506115108282611930565b50909695505050505050565b6001600160a01b0384166115455760405163e602df0560e01b81525f60048201526024016107f1565b6001600160a01b03831661156e57604051634a1406b160e11b81525f60048201526024016107f1565b6001600160a01b038085165f9081526001602090815260408083209387168352929052208290558015610d8457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516115e091815260200190565b60405180910390a350505050565b600854600160a01b900460ff1680156116165750611d4c600c546116129190612070565b4211155b80156116305750601054600f5461162d9190612051565b81115b801561164a5750600a546001600160a01b03848116911614155b801561166457506008546001600160a01b03848116911614155b801561167857506001600160a01b03831615155b15611788578061169c846001600160a01b03165f9081526020819052604090205490565b10156116f95760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016107f1565b5f5f611704836119e8565b90925090508015611770576009546117279086906001600160a01b031683611aad565b6040805132815260208101859052908101839052606081018290527f919599b3adfc944b6ffc7b5fbe435d0dada323806241378ded1cad95f2e4121d9060800160405180910390a15b811561178157611781858584611aad565b5050611793565b611793838383611aad565b6001600160a01b0383165f9081526011602052604090205460ff166001036111b4576111b48382611bd3565b606060ff83146117d9576117d283611ce3565b90506106e6565b8180546117e590612002565b80601f016020809104026020016040519081016040528092919081815260200182805461181190612002565b801561185c5780601f106118335761010080835404028352916020019161185c565b820191905f5260205f20905b81548152906001019060200180831161183f57829003601f168201915b505050505090506106e6565b5f80807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08411156118a157505f91506003905082611926565b604080515f808252602082018084528a905260ff891692820192909252606081018790526080810186905260019060a0016020604051602081039080840390855afa1580156118f2573d5f5f3e3d5ffd5b5050604051601f1901519150506001600160a01b03811661191d57505f925060019150829050611926565b92505f91508190505b9450945094915050565b5f82600381111561194357611943612097565b0361194c575050565b600182600381111561196057611960612097565b0361197e5760405163f645eedf60e01b815260040160405180910390fd5b600282600381111561199257611992612097565b036119b35760405163fce698f760e01b8152600481018290526024016107f1565b60038260038111156119c7576119c7612097565b03611415576040516335e2f38360e21b8152600481018290526024016107f1565b5f5f5f600c54426119f99190611fef565b90505f601054600f54611a0c9190612051565b90505f611a198287611fef565b90505f611d4c611a298582611fef565b611a3490606461203a565b611a3e9190612051565b90505f611a4b8385612070565b611a5684606461203a565b611a609190612051565b90505f6064611a6f838561203a565b611a799190612051565b90505f6064611a88838761203a565b611a929190612051565b9050611a9e818b611fef565b9a909950975050505050505050565b6001600160a01b038316611ad7578060025f828254611acc9190612070565b90915550611b479050565b6001600160a01b0383165f9081526020819052604090205481811015611b295760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016107f1565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611b6357600280548290039055611b81565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611bc691815260200190565b60405180910390a3505050565b611bdc82611175565b15611c09576001600160a01b0382165f908152601160205260409020426002820155600301819055611c39565b6001600160a01b0382165f9081526011602052604081206003018054839290611c33908490612070565b90915550505b6001600160a01b0382165f9081526011602052604081206001015490819003611c615750600f545b6001600160a01b0383165f908152601160205260409020600301548110156111b4576001600160a01b0383165f8181526011602052604090819020805460ff191660021781556003015490517ff3baa52f900a58295c5dcdd74f103ba109926ee544d3fc43547540aa482fadbf91610a9d918590918252602082015260400190565b60605f611cef83611d20565b6040805160208082528183019092529192505f91906020820181803683375050509182525060208101929092525090565b5f60ff8216601f8111156106e657604051632cd44ac360e21b815260040160405180910390fd5b80356001600160a01b038116811461063e575f5ffd5b5f60208284031215611d6d575f5ffd5b611d7682611d47565b9392505050565b5f81518084528060208401602086015e5f602082860101526020601f19601f83011685010191505092915050565b602081525f611d766020830184611d7d565b5f5f60408385031215611dce575f5ffd5b611dd783611d47565b946020939093013593505050565b5f5f5f60608486031215611df7575f5ffd5b611e0084611d47565b9250611e0e60208501611d47565b929592945050506040919091013590565b60ff60f81b8816815260e060208201525f611e3d60e0830189611d7d565b8281036040840152611e4f8189611d7d565b606084018890526001600160a01b038716608085015260a0840186905283810360c0850152845180825260208087019350909101905f5b81811015611ea4578351835260209384019390920191600101611e86565b50909b9a5050505050505050505050565b5f60208284031215611ec5575f5ffd5b5035919050565b5f5f60208385031215611edd575f5ffd5b823567ffffffffffffffff811115611ef3575f5ffd5b8301601f81018513611f03575f5ffd5b803567ffffffffffffffff811115611f19575f5ffd5b8560208260051b8401011115611f2d575f5ffd5b6020919091019590945092505050565b5f5f5f5f5f5f5f60e0888a031215611f53575f5ffd5b611f5c88611d47565b9650611f6a60208901611d47565b95506040880135945060608801359350608088013560ff81168114611f8d575f5ffd5b9699959850939692959460a0840135945060c09093013592915050565b5f5f60408385031215611fbb575f5ffd5b611fc483611d47565b9150611fd260208401611d47565b90509250929050565b634e487b7160e01b5f52601160045260245ffd5b818103818111156106e6576106e6611fdb565b600181811c9082168061201657607f821691505b60208210810361203457634e487b7160e01b5f52602260045260245ffd5b50919050565b80820281158282048414176106e6576106e6611fdb565b5f8261206b57634e487b7160e01b5f52601260045260245ffd5b500490565b808201808211156106e6576106e6611fdb565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52602160045260245ffdfea2646970667358221220a34747e21821bbf2984550af2a3d7f8957222664c4d67cf68cb2b3637ba32b0364736f6c634300081c0033

Deployed Bytecode

0x608060405234801561000f575f5ffd5b5060043610610228575f3560e01c80638da5cb5b1161012a578063c1361d3b116100b4578063db15d18511610079578063db15d185146104c1578063dd62ed3e146104d4578063ea6270001461050c578063f2fde38b14610514578063f9e19aed14610527575f5ffd5b8063c1361d3b14610423578063ca86f96a1461042c578063cfe7f8581461043f578063d505accf14610452578063dadb40d914610465575f5ffd5b8063a4ef49c4116100fa578063a4ef49c4146103d9578063a6091aaa146103e1578063a9059cbb146103ea578063b1059d8b146103fd578063b3f0067414610410575f5ffd5b80638da5cb5b1461039957806391e12d8d146103aa57806395d89b41146103be578063a3c958e0146103c6575f5ffd5b8063331babd7116101b6578063715018a61161017b578063715018a6146103525780637ecebe001461035a57806384b0196e1461036d57806388ffe867146103885780638a161a3314610390575f5ffd5b8063331babd7146102f15780633644e5151461030457806340c10f191461030c57806350f7c2041461032157806370a082311461032a575f5ffd5b806318160ddd116101fc57806318160ddd1461029357806320ca3c7f1461029b57806323b872dd146102c6578063265c82eb146102d9578063313ce567146102e2575f5ffd5b8062b61dd91461022c57806306950d1c1461025257806306fdde031461025b578063095ea7b314610270575b5f5ffd5b61023f61023a366004611d5d565b61056b565b6040519081526020015b60405180910390f35b61023f611d4c81565b610263610643565b6040516102499190611dab565b61028361027e366004611dbd565b6106d3565b6040519015158152602001610249565b60025461023f565b600a546102ae906001600160a01b031681565b6040516001600160a01b039091168152602001610249565b6102836102d4366004611de5565b6106ec565b61023f600c5481565b60405160128152602001610249565b61023f6102ff366004611d5d565b61070f565b61023f610765565b61031f61031a366004611dbd565b610773565b005b61023f600d5481565b61023f610338366004611d5d565b6001600160a01b03165f9081526020819052604090205490565b61031f6108be565b61023f610368366004611d5d565b6108d1565b6103756108ee565b6040516102499796959493929190611e1f565b61031f610930565b61023f600f5481565b6008546001600160a01b03166102ae565b60085461028390600160a01b900460ff1681565b610263610aaa565b61031f6103d4366004611eb5565b610ab9565b61031f610b07565b61023f600b5481565b6102836103f8366004611dbd565b610b78565b61031f61040b366004611ecc565b610b85565b6009546102ae906001600160a01b031681565b61023f600e5481565b61031f61043a366004611d5d565b610d8a565b61023f61044d366004611d5d565b610e1c565b61031f610460366004611f3d565b610e64565b61049d610473366004611d5d565b60116020525f9081526040902080546001820154600283015460039093015460ff90921692909184565b6040805160ff90951685526020850193909352918301526060820152608001610249565b61031f6104cf366004611d5d565b610f9a565b61023f6104e2366004611faa565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b61031f610fc4565b61031f610522366004611d5d565b6110be565b61053a610535366004611d5d565b6110fb565b6040805160ff90971687526020870195909552938501929092526060840152608083015260a082015260c001610249565b6001600160a01b0381165f9081526011602052604081205460ff16600103610637576001600160a01b0382165f908152601160205260408120600101548082036105b45750600f545b6105bd84611175565b156105ca578091506105f2565b6001600160a01b0384165f908152601160205260409020600301546105ef9082611fef565b91505b6001600160a01b0384165f908152602081905260409020548211610616578161062f565b6001600160a01b0384165f908152602081905260409020545b949350505050565b505f919050565b919050565b60606003805461065290612002565b80601f016020809104026020016040519081016040528092919081815260200182805461067e90612002565b80156106c95780601f106106a0576101008083540402835291602001916106c9565b820191905f5260205f20905b8154815290600101906020018083116106ac57829003601f168201915b5050505050905090565b5f336106e08185856111a7565b60019150505b92915050565b5f336106f98582856111b9565b61070485858561122e565b506001949350505050565b6001600160a01b0381165f9081526011602052604081205460ff16600103610637576001600160a01b0382165f90815260116020526040812060010154908190036107595750600f545b5f61062f82606461203a565b5f61076e61128b565b905090565b61077b6113b4565b600a600d5461078a9190612051565b81600b546107989190612070565b11156107fa5760405162461bcd60e51b815260206004820152602660248201527f313025204d415820535550504c59204e4f4e2d41495244524f50204341502052604482015265115050d2115160d21b60648201526084015b60405180910390fd5b5f811180156108175750600d546002546108149083612070565b11155b6108525760405162461bcd60e51b815260206004820152600c60248201526b15d493d391c8105353d5539560a21b60448201526064016107f1565b6001600160a01b03821661089a5760405162461bcd60e51b815260206004820152600f60248201526e494e56414c4944204144445245535360881b60448201526064016107f1565b6108a482826113e1565b80600b5f8282546108b59190612070565b90915550505050565b6108c66113b4565b6108cf5f611419565b565b6001600160a01b0381165f908152600760205260408120546106e6565b5f6060805f5f5f60606108ff61146a565b610907611497565b604080515f80825260208201909252600f60f81b9b939a50919850469750309650945092509050565b335f818152602081815260408083205460119092529091205460ff1660020361098f5760405162461bcd60e51b8152602060048201526011602482015270484153204641494c454420504c4544474560781b60448201526064016107f1565b60648110156109e05760405162461bcd60e51b815260206004820152601a60248201527f4d555354204f574e203e3d20313030204241534520554e49545300000000000060448201526064016107f1565b5f6109ea8361070f565b905080821015610a335760405162461bcd60e51b815260206004820152601460248201527343414e4e4f542052454455434520504c4544474560601b60448201526064016107f1565b610a3e606483612051565b6001600160a01b0384165f8181526011602052604090819020600180820194909455805460ff191690931790925590517f8befdfb767f1fa8afaab1250205358276a8dfd21b2d744e0c068ec9ce67f70e290610a9d9085815260200190565b60405180910390a2505050565b60606004805461065290612002565b610ac16113b4565b5f8111610b025760405162461bcd60e51b815260206004820152600f60248201526e24a72b20a624a22fa224ab24a9a7a960891b60448201526064016107f1565b601055565b610b0f6113b4565b6008805460ff60a01b19169081905560095460408051600160a01b90930460ff16151583526001600160a01b03909116602083015242908201527f2e38c7ebc623cd6558435b9be0c24407b17e2981956d8082c95231e8713113de9060600160405180910390a1565b5f336106e081858561122e565b610b8d6113b4565b600d548190606490610ba090605a61203a565b610baa9190612051565b600e54610bb7908361203a565b600b54600254610bc79190611fef565b610bd19190612070565b1115610c2a5760405162461bcd60e51b815260206004820152602260248201527f393025204d415820535550504c592041495244524f5020434150205245414348604482015261115160f21b60648201526084016107f1565b5f5b81811015610d845760115f858584818110610c4957610c49612083565b9050602002016020810190610c5e9190611d5d565b6001600160a01b0316815260208101919091526040015f205460ff16158015610cb657505f848483818110610c9557610c95612083565b9050602002016020810190610caa9190611d5d565b6001600160a01b031614155b610cf45760405162461bcd60e51b815260206004820152600f60248201526e24a72b20a624a210282622a223a2a960891b60448201526064016107f1565b610d26848483818110610d0957610d09612083565b9050602002016020810190610d1e9190611d5d565b600e546113e1565b600160115f868685818110610d3d57610d3d612083565b9050602002016020810190610d529190611d5d565b6001600160a01b0316815260208101919091526040015f20805460ff191660ff92909216919091179055600101610c2c565b50505050565b610d926113b4565b600980546001600160a01b0383166001600160a01b031990911681179091556008805460ff60a01b1916600160a01b9081179182905542600c819055604080519290930460ff16151582526020820193909352908101919091527f2e38c7ebc623cd6558435b9be0c24407b17e2981956d8082c95231e8713113de9060600160405180910390a150565b5f610e2682611175565b15610e3257505f919050565b6001600160a01b0382165f90815260116020526040902060020154610e579042611fef565b6106e69062278d00611fef565b83421115610e885760405163313c898160e11b8152600481018590526024016107f1565b5f7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9888888610ed38c6001600160a01b03165f90815260076020526040902080546001810190915590565b6040805160208101969096526001600160a01b0394851690860152929091166060840152608083015260a082015260c0810186905260e0016040516020818303038152906040528051906020012090505f610f2d826114c4565b90505f610f3c828787876114f0565b9050896001600160a01b0316816001600160a01b031614610f83576040516325c0072360e11b81526001600160a01b0380831660048301528b1660248201526044016107f1565b610f8e8a8a8a6111a7565b50505050505050505050565b610fa26113b4565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b335f8181526011602052604090205460ff166001146110185760405162461bcd60e51b815260206004820152601060248201526f4e4f2041435449564520504c4544474560801b60448201526064016107f1565b6001600160a01b0381165f90815260208190526040902054156110735760405162461bcd60e51b81526020600482015260136024820152724d555354204841564520302042414c414e434560681b60448201526064016107f1565b6001600160a01b0381165f81815260116020526040808220805460ff19166003179055517f5db4685c003ecba127ab382661505e1ea89db4bf387b04ce97d1d15874a03a529190a250565b6110c66113b4565b6001600160a01b0381166110ef57604051631e4fbdf760e01b81525f60048201526024016107f1565b6110f881611419565b50565b6001600160a01b0381165f90815260116020908152604080832054918390528220548291829182918291829160ff16906111348961070f565b6001600160a01b038a165f908152601160205260409020600301546111588b61056b565b6111618c610e1c565b949c939b5091995097509550909350915050565b6001600160a01b0381165f9081526011602052604081206002015462278d009061119f9042611fef565b101592915050565b6111b4838383600161151c565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198114610d84578181101561122057604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064016107f1565b610d8484848484035f61151c565b6001600160a01b03831661125757604051634b637e8f60e11b81525f60048201526024016107f1565b6001600160a01b0382166112805760405163ec442f0560e01b81525f60048201526024016107f1565b6111b48383836115ee565b5f306001600160a01b037f000000000000000000000000910812c44ed2a3b611e4b051d9d83a88d652e2dd161480156112e357507f000000000000000000000000000000000000000000000000000000000000000146145b1561130d57507f62c34e249ca0fab891a94ae6cfcd530ec363ab7bc718d8cf687f32cfc62f37d990565b61076e604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f60208201527f4cdce9d885cd3eabfe5ec7689a5671fa40f5093d9ea01aaf435775b29c50ad54918101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a08201525f9060c00160405160208183030381529060405280519060200120905090565b6008546001600160a01b031633146108cf5760405163118cdaa760e01b81523360048201526024016107f1565b6001600160a01b03821661140a5760405163ec442f0560e01b81525f60048201526024016107f1565b6114155f83836115ee565b5050565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b606061076e7f504c45444745000000000000000000000000000000000000000000000000000660056117bf565b606061076e7f310000000000000000000000000000000000000000000000000000000000000160066117bf565b5f6106e66114d061128b565b8360405161190160f01b8152600281019290925260228201526042902090565b5f5f5f5f61150088888888611868565b9250925092506115108282611930565b50909695505050505050565b6001600160a01b0384166115455760405163e602df0560e01b81525f60048201526024016107f1565b6001600160a01b03831661156e57604051634a1406b160e11b81525f60048201526024016107f1565b6001600160a01b038085165f9081526001602090815260408083209387168352929052208290558015610d8457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516115e091815260200190565b60405180910390a350505050565b600854600160a01b900460ff1680156116165750611d4c600c546116129190612070565b4211155b80156116305750601054600f5461162d9190612051565b81115b801561164a5750600a546001600160a01b03848116911614155b801561166457506008546001600160a01b03848116911614155b801561167857506001600160a01b03831615155b15611788578061169c846001600160a01b03165f9081526020819052604090205490565b10156116f95760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016107f1565b5f5f611704836119e8565b90925090508015611770576009546117279086906001600160a01b031683611aad565b6040805132815260208101859052908101839052606081018290527f919599b3adfc944b6ffc7b5fbe435d0dada323806241378ded1cad95f2e4121d9060800160405180910390a15b811561178157611781858584611aad565b5050611793565b611793838383611aad565b6001600160a01b0383165f9081526011602052604090205460ff166001036111b4576111b48382611bd3565b606060ff83146117d9576117d283611ce3565b90506106e6565b8180546117e590612002565b80601f016020809104026020016040519081016040528092919081815260200182805461181190612002565b801561185c5780601f106118335761010080835404028352916020019161185c565b820191905f5260205f20905b81548152906001019060200180831161183f57829003601f168201915b505050505090506106e6565b5f80807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08411156118a157505f91506003905082611926565b604080515f808252602082018084528a905260ff891692820192909252606081018790526080810186905260019060a0016020604051602081039080840390855afa1580156118f2573d5f5f3e3d5ffd5b5050604051601f1901519150506001600160a01b03811661191d57505f925060019150829050611926565b92505f91508190505b9450945094915050565b5f82600381111561194357611943612097565b0361194c575050565b600182600381111561196057611960612097565b0361197e5760405163f645eedf60e01b815260040160405180910390fd5b600282600381111561199257611992612097565b036119b35760405163fce698f760e01b8152600481018290526024016107f1565b60038260038111156119c7576119c7612097565b03611415576040516335e2f38360e21b8152600481018290526024016107f1565b5f5f5f600c54426119f99190611fef565b90505f601054600f54611a0c9190612051565b90505f611a198287611fef565b90505f611d4c611a298582611fef565b611a3490606461203a565b611a3e9190612051565b90505f611a4b8385612070565b611a5684606461203a565b611a609190612051565b90505f6064611a6f838561203a565b611a799190612051565b90505f6064611a88838761203a565b611a929190612051565b9050611a9e818b611fef565b9a909950975050505050505050565b6001600160a01b038316611ad7578060025f828254611acc9190612070565b90915550611b479050565b6001600160a01b0383165f9081526020819052604090205481811015611b295760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016107f1565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611b6357600280548290039055611b81565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611bc691815260200190565b60405180910390a3505050565b611bdc82611175565b15611c09576001600160a01b0382165f908152601160205260409020426002820155600301819055611c39565b6001600160a01b0382165f9081526011602052604081206003018054839290611c33908490612070565b90915550505b6001600160a01b0382165f9081526011602052604081206001015490819003611c615750600f545b6001600160a01b0383165f908152601160205260409020600301548110156111b4576001600160a01b0383165f8181526011602052604090819020805460ff191660021781556003015490517ff3baa52f900a58295c5dcdd74f103ba109926ee544d3fc43547540aa482fadbf91610a9d918590918252602082015260400190565b60605f611cef83611d20565b6040805160208082528183019092529192505f91906020820181803683375050509182525060208101929092525090565b5f60ff8216601f8111156106e657604051632cd44ac360e21b815260040160405180910390fd5b80356001600160a01b038116811461063e575f5ffd5b5f60208284031215611d6d575f5ffd5b611d7682611d47565b9392505050565b5f81518084528060208401602086015e5f602082860101526020601f19601f83011685010191505092915050565b602081525f611d766020830184611d7d565b5f5f60408385031215611dce575f5ffd5b611dd783611d47565b946020939093013593505050565b5f5f5f60608486031215611df7575f5ffd5b611e0084611d47565b9250611e0e60208501611d47565b929592945050506040919091013590565b60ff60f81b8816815260e060208201525f611e3d60e0830189611d7d565b8281036040840152611e4f8189611d7d565b606084018890526001600160a01b038716608085015260a0840186905283810360c0850152845180825260208087019350909101905f5b81811015611ea4578351835260209384019390920191600101611e86565b50909b9a5050505050505050505050565b5f60208284031215611ec5575f5ffd5b5035919050565b5f5f60208385031215611edd575f5ffd5b823567ffffffffffffffff811115611ef3575f5ffd5b8301601f81018513611f03575f5ffd5b803567ffffffffffffffff811115611f19575f5ffd5b8560208260051b8401011115611f2d575f5ffd5b6020919091019590945092505050565b5f5f5f5f5f5f5f60e0888a031215611f53575f5ffd5b611f5c88611d47565b9650611f6a60208901611d47565b95506040880135945060608801359350608088013560ff81168114611f8d575f5ffd5b9699959850939692959460a0840135945060c09093013592915050565b5f5f60408385031215611fbb575f5ffd5b611fc483611d47565b9150611fd260208401611d47565b90509250929050565b634e487b7160e01b5f52601160045260245ffd5b818103818111156106e6576106e6611fdb565b600181811c9082168061201657607f821691505b60208210810361203457634e487b7160e01b5f52602260045260245ffd5b50919050565b80820281158282048414176106e6576106e6611fdb565b5f8261206b57634e487b7160e01b5f52601260045260245ffd5b500490565b808201808211156106e6576106e6611fdb565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52602160045260245ffdfea2646970667358221220a34747e21821bbf2984550af2a3d7f8957222664c4d67cf68cb2b3637ba32b0364736f6c634300081c0033

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.