Overview
ETH Balance
More Info
ContractCreator
Multichain Info
Latest 25 from a total of 140 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Nuke | 6330573 | 275 days ago | IN | 0 ETH | 0.00022964 | ||||
Nuke | 6330566 | 275 days ago | IN | 0 ETH | 0.00022945 | ||||
Nuke | 6330336 | 275 days ago | IN | 0 ETH | 0.0002433 | ||||
Nuke | 6327912 | 275 days ago | IN | 0 ETH | 0.00514797 | ||||
Nuke | 6327894 | 275 days ago | IN | 0 ETH | 0.00564442 | ||||
Nuke | 6326527 | 275 days ago | IN | 0 ETH | 0.00339291 | ||||
Nuke | 6325740 | 276 days ago | IN | 0 ETH | 0.00114215 | ||||
Nuke | 6325473 | 276 days ago | IN | 0 ETH | 0.00054247 | ||||
Nuke | 6324238 | 276 days ago | IN | 0 ETH | 0.00022406 | ||||
Nuke | 6324194 | 276 days ago | IN | 0 ETH | 0.00022836 | ||||
Nuke | 6324186 | 276 days ago | IN | 0 ETH | 0.00027635 | ||||
Nuke | 6324090 | 276 days ago | IN | 0 ETH | 0.00024282 | ||||
Nuke | 6324084 | 276 days ago | IN | 0 ETH | 0.00026002 | ||||
Nuke | 6321269 | 276 days ago | IN | 0 ETH | 0.00092069 | ||||
Nuke | 6321150 | 276 days ago | IN | 0 ETH | 0.00074086 | ||||
Nuke | 6319679 | 277 days ago | IN | 0 ETH | 0.000786 | ||||
Nuke | 6319674 | 277 days ago | IN | 0 ETH | 0.00094564 | ||||
Nuke | 6318867 | 277 days ago | IN | 0 ETH | 0.00022924 | ||||
Nuke | 6318282 | 277 days ago | IN | 0 ETH | 0.00103147 | ||||
Nuke | 6318108 | 277 days ago | IN | 0 ETH | 0.00099183 | ||||
Nuke | 6316666 | 277 days ago | IN | 0 ETH | 0.00029686 | ||||
Nuke | 6316658 | 277 days ago | IN | 0 ETH | 0.00032415 | ||||
Nuke | 6316551 | 277 days ago | IN | 0 ETH | 0.00028236 | ||||
Nuke | 6316519 | 277 days ago | IN | 0 ETH | 0.00034628 | ||||
Nuke | 6316478 | 277 days ago | IN | 0 ETH | 0.00033905 |
Latest 25 internal transactions (View All)
Parent Transaction Hash | Method | Block |
From
|
To
|
|||
---|---|---|---|---|---|---|---|
Transfer | 6330686 | 275 days ago | 0.005 ETH | ||||
Transfer | 6330686 | 275 days ago | 0.05 ETH | ||||
Transfer | 6330672 | 275 days ago | 0.01653 ETH | ||||
Transfer | 6330672 | 275 days ago | 0.1653 ETH | ||||
Transfer | 6330669 | 275 days ago | 0.01652 ETH | ||||
Transfer | 6330669 | 275 days ago | 0.1652 ETH | ||||
Transfer | 6330664 | 275 days ago | 0.01651 ETH | ||||
Transfer | 6330664 | 275 days ago | 0.1651 ETH | ||||
Transfer | 6330657 | 275 days ago | 0.0165 ETH | ||||
Transfer | 6330657 | 275 days ago | 0.165 ETH | ||||
Transfer | 6330573 | 275 days ago | 0.25609779 ETH | ||||
Transfer | 6330566 | 275 days ago | 0.35007455 ETH | ||||
Transfer | 6330409 | 275 days ago | 0.01649 ETH | ||||
Transfer | 6330409 | 275 days ago | 0.1649 ETH | ||||
Transfer | 6330408 | 275 days ago | 0.01648 ETH | ||||
Transfer | 6330408 | 275 days ago | 0.1648 ETH | ||||
Transfer | 6330336 | 275 days ago | 0.45002691 ETH | ||||
Transfer | 6330330 | 275 days ago | 0.002 ETH | ||||
Transfer | 6330330 | 275 days ago | 0.02 ETH | ||||
Transfer | 6327912 | 275 days ago | 0.34292446 ETH | ||||
Transfer | 6327901 | 275 days ago | 0.01647 ETH | ||||
Transfer | 6327901 | 275 days ago | 0.1647 ETH | ||||
Transfer | 6327899 | 275 days ago | 0.01646 ETH | ||||
Transfer | 6327899 | 275 days ago | 0.1646 ETH | ||||
Transfer | 6327897 | 275 days ago | 0.01645 ETH |
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity ^0.8.20; import '@openzeppelin/contracts/access/Ownable.sol'; import '@openzeppelin/contracts/security/ReentrancyGuard.sol'; import '@openzeppelin/contracts/security/Pausable.sol'; import './INukeFund.sol'; import '../TraitForgeNft/ITraitForgeNft.sol'; import '../Airdrop/IAirdrop.sol'; contract NukeFund is INukeFund, ReentrancyGuard, Ownable, Pausable { uint256 public constant MAX_DENOMINATOR = 100000; uint256 private fund; ITraitForgeNft public nftContract; IAirdrop public airdropContract; address payable public devAddress; address payable public daoAddress; uint256 public taxCut = 10; uint256 public defaultNukeFactorIncrease = 250; uint256 public maxAllowedClaimDivisor = 2; uint256 public nukeFactorMaxParam = MAX_DENOMINATOR / 2; uint256 public minimumDaysHeld = 3 days; uint256 public ageMultiplier; // Constructor now properly passes the initial owner address to the Ownable constructor constructor( address _traitForgeNft, address _airdrop, address payable _devAddress, address payable _daoAddress ) { nftContract = ITraitForgeNft(_traitForgeNft); airdropContract = IAirdrop(_airdrop); devAddress = _devAddress; // Set the developer's address daoAddress = _daoAddress; } // Fallback function to receive ETH and update fund balance receive() external payable { uint256 devShare = msg.value / taxCut; // Calculate developer's share (10%) uint256 remainingFund = msg.value - devShare; // Calculate remaining funds to add to the fund fund += remainingFund; // Update the fund balance if (!airdropContract.airdropStarted()) { (bool success, ) = devAddress.call{ value: devShare }(''); require(success, 'ETH send failed'); emit DevShareDistributed(devShare); } else if (!airdropContract.daoFundAllowed()) { (bool success, ) = payable(owner()).call{ value: devShare }(''); require(success, 'ETH send failed'); } else { (bool success, ) = daoAddress.call{ value: devShare }(''); require(success, 'ETH send failed'); emit DevShareDistributed(devShare); } emit FundReceived(msg.sender, msg.value); // Log the received funds emit FundBalanceUpdated(fund); // Update the fund balance } function setTaxCut(uint256 _taxCut) external onlyOwner { taxCut = _taxCut; } function setMinimumDaysHeld(uint256 value) external onlyOwner { minimumDaysHeld = value; } function setDefaultNukeFactorIncrease(uint256 value) external onlyOwner { defaultNukeFactorIncrease = value; } function setMaxAllowedClaimDivisor(uint256 value) external onlyOwner { maxAllowedClaimDivisor = value; } function setNukeFactorMaxParam(uint256 value) external onlyOwner { nukeFactorMaxParam = value; } // Allow the owner to update the reference to the ERC721 contract function setTraitForgeNftContract(address _traitForgeNft) external onlyOwner { nftContract = ITraitForgeNft(_traitForgeNft); emit TraitForgeNftAddressUpdated(_traitForgeNft); // Emit an event when the address is updated. } function setAirdropContract(address _airdrop) external onlyOwner { airdropContract = IAirdrop(_airdrop); emit AirdropAddressUpdated(_airdrop); // Emit an event when the address is updated. } function setDevAddress(address payable account) external onlyOwner { devAddress = account; emit DevAddressUpdated(account); } function setDaoAddress(address payable account) external onlyOwner { daoAddress = account; emit DaoAddressUpdated(account); } // View function to see the current balance of the fund function getFundBalance() public view returns (uint256) { return fund; } function setAgeMultplier(uint256 _ageMultiplier) external onlyOwner { ageMultiplier = _ageMultiplier; } function getAgeMultiplier() public view returns (uint256) { return ageMultiplier; } // Calculate the age of a token based on its creation timestamp and current time function calculateAge(uint256 tokenId) public view returns (uint256) { require(nftContract.ownerOf(tokenId) != address(0), 'Token does not exist'); uint256 daysOld = (block.timestamp - nftContract.getTokenCreationTimestamp(tokenId)) / 60 / 60 / 24; uint256 perfomanceFactor = nftContract.getTokenEntropy(tokenId) % 10; uint256 age = (daysOld * perfomanceFactor * MAX_DENOMINATOR * ageMultiplier) / 365; // add 5 digits for decimals return age; } // Calculate the nuke factor of a token, which affects the claimable amount from the fund function calculateNukeFactor(uint256 tokenId) public view returns (uint256) { require( nftContract.ownerOf(tokenId) != address(0), 'ERC721: operator query for nonexistent token' ); uint256 entropy = nftContract.getTokenEntropy(tokenId); uint256 adjustedAge = calculateAge(tokenId); uint256 initialNukeFactor = entropy / 40; // calcualte initalNukeFactor based on entropy, 5 digits uint256 finalNukeFactor = ((adjustedAge * defaultNukeFactorIncrease) / MAX_DENOMINATOR) + initialNukeFactor; return finalNukeFactor; } function nuke(uint256 tokenId) public whenNotPaused nonReentrant { require( nftContract.isApprovedOrOwner(msg.sender, tokenId), 'ERC721: caller is not token owner or approved' ); require( nftContract.getApproved(tokenId) == address(this) || nftContract.isApprovedForAll(msg.sender, address(this)), 'Contract must be approved to transfer the NFT.' ); require(canTokenBeNuked(tokenId), 'Token is not mature yet'); uint256 finalNukeFactor = calculateNukeFactor(tokenId); // finalNukeFactor has 5 digits uint256 potentialClaimAmount = (fund * finalNukeFactor) / MAX_DENOMINATOR; // Calculate the potential claim amount based on the finalNukeFactor uint256 maxAllowedClaimAmount = fund / maxAllowedClaimDivisor; // Define a maximum allowed claim amount as 50% of the current fund size // Directly assign the value to claimAmount based on the condition, removing the redeclaration uint256 claimAmount = finalNukeFactor > nukeFactorMaxParam ? maxAllowedClaimAmount : potentialClaimAmount; fund -= claimAmount; // Deduct the claim amount from the fund nftContract.burn(tokenId); // Burn the token (bool success, ) = payable(msg.sender).call{ value: claimAmount }(''); require(success, 'Failed to send Ether'); emit Nuked(msg.sender, tokenId, claimAmount); // Emit the event with the actual claim amount emit FundBalanceUpdated(fund); // Update the fund balance } function canTokenBeNuked(uint256 tokenId) public view returns (bool) { // Ensure the token exists require( nftContract.ownerOf(tokenId) != address(0), 'ERC721: operator query for nonexistent token' ); // Get the age of the token in seconds from the ERC721 contract uint256 tokenAgeInSeconds = nftContract.getTokenAge(tokenId); // Assuming tokenAgeInSeconds is the age of the token since its creation, check if it's at least 3 days old return tokenAgeInSeconds >= minimumDaysHeld; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol) pragma solidity ^0.8.0; import "../utils/Context.sol"; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby disabling any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol) pragma solidity ^0.8.0; import "../utils/Context.sol"; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * * This module is used through inheritance. It will make available the * modifiers `whenNotPaused` and `whenPaused`, which can be applied to * the functions of your contract. Note that they will not be pausable by * simply including this module, only once the modifiers are put in place. */ abstract contract Pausable is Context { /** * @dev Emitted when the pause is triggered by `account`. */ event Paused(address account); /** * @dev Emitted when the pause is lifted by `account`. */ event Unpaused(address account); bool private _paused; /** * @dev Initializes the contract in unpaused state. */ constructor() { _paused = false; } /** * @dev Modifier to make a function callable only when the contract is not paused. * * Requirements: * * - The contract must not be paused. */ modifier whenNotPaused() { _requireNotPaused(); _; } /** * @dev Modifier to make a function callable only when the contract is paused. * * Requirements: * * - The contract must be paused. */ modifier whenPaused() { _requirePaused(); _; } /** * @dev Returns true if the contract is paused, and false otherwise. */ function paused() public view virtual returns (bool) { return _paused; } /** * @dev Throws if the contract is paused. */ function _requireNotPaused() internal view virtual { require(!paused(), "Pausable: paused"); } /** * @dev Throws if the contract is not paused. */ function _requirePaused() internal view virtual { require(paused(), "Pausable: not paused"); } /** * @dev Triggers stopped state. * * Requirements: * * - The contract must not be paused. */ function _pause() internal virtual whenNotPaused { _paused = true; emit Paused(_msgSender()); } /** * @dev Returns to normal state. * * Requirements: * * - The contract must be paused. */ function _unpause() internal virtual whenPaused { _paused = false; emit Unpaused(_msgSender()); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (security/ReentrancyGuard.sol) pragma solidity ^0.8.0; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant _NOT_ENTERED = 1; uint256 private constant _ENTERED = 2; uint256 private _status; constructor() { _status = _NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be _NOT_ENTERED require(_status != _ENTERED, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _status = _ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = _NOT_ENTERED; } /** * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a * `nonReentrant` function in the call stack. */ function _reentrancyGuardEntered() internal view returns (bool) { return _status == _ENTERED; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.5.0) (token/ERC721/extensions/IERC721Enumerable.sol) pragma solidity ^0.8.0; import "../IERC721.sol"; /** * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension * @dev See https://eips.ethereum.org/EIPS/eip-721 */ interface IERC721Enumerable is IERC721 { /** * @dev Returns the total amount of tokens stored by the contract. */ function totalSupply() external view returns (uint256); /** * @dev Returns a token ID owned by `owner` at a given `index` of its token list. * Use along with {balanceOf} to enumerate all of ``owner``'s tokens. */ function tokenOfOwnerByIndex(address owner, uint256 index) external view returns (uint256); /** * @dev Returns a token ID at a given `index` of all the tokens stored by the contract. * Use along with {totalSupply} to enumerate all tokens. */ function tokenByIndex(uint256 index) external view returns (uint256); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC721/IERC721.sol) pragma solidity ^0.8.0; import "../../utils/introspection/IERC165.sol"; /** * @dev Required interface of an ERC721 compliant contract. */ interface IERC721 is IERC165 { /** * @dev Emitted when `tokenId` token is transferred from `from` to `to`. */ event Transfer(address indexed from, address indexed to, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token. */ event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets. */ event ApprovalForAll(address indexed owner, address indexed operator, bool approved); /** * @dev Returns the number of tokens in ``owner``'s account. */ function balanceOf(address owner) external view returns (uint256 balance); /** * @dev Returns the owner of the `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function ownerOf(uint256 tokenId) external view returns (address owner); /** * @dev Safely transfers `tokenId` token from `from` to `to`. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function safeTransferFrom(address from, address to, uint256 tokenId, bytes calldata data) external; /** * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients * are aware of the ERC721 protocol to prevent tokens from being forever locked. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function safeTransferFrom(address from, address to, uint256 tokenId) external; /** * @dev Transfers `tokenId` token from `from` to `to`. * * WARNING: Note that the caller is responsible to confirm that the recipient is capable of receiving ERC721 * or else they may be permanently lost. Usage of {safeTransferFrom} prevents loss, though the caller must * understand this adds an external call which potentially creates a reentrancy vulnerability. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must be owned by `from`. * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 tokenId) external; /** * @dev Gives permission to `to` to transfer `tokenId` token to another account. * The approval is cleared when the token is transferred. * * Only a single account can be approved at a time, so approving the zero address clears previous approvals. * * Requirements: * * - The caller must own the token or be an approved operator. * - `tokenId` must exist. * * Emits an {Approval} event. */ function approve(address to, uint256 tokenId) external; /** * @dev Approve or remove `operator` as an operator for the caller. * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller. * * Requirements: * * - The `operator` cannot be the caller. * * Emits an {ApprovalForAll} event. */ function setApprovalForAll(address operator, bool approved) external; /** * @dev Returns the account approved for `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function getApproved(uint256 tokenId) external view returns (address operator); /** * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`. * * See {setApprovalForAll} */ function isApprovedForAll(address owner, address operator) external view returns (bool); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC165 standard, as defined in the * https://eips.ethereum.org/EIPS/eip-165[EIP]. * * Implementers can declare support of contract interfaces, which can then be * queried by others ({ERC165Checker}). * * For an implementation, see {ERC165}. */ interface IERC165 { /** * @dev Returns true if this contract implements the interface defined by * `interfaceId`. See the corresponding * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] * to learn more about how these ids are created. * * This function call must use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.20; interface IAirdrop { function setTraitToken(address _traitToken) external; function startAirdrop(uint256 amount) external; function airdropStarted() external view returns (bool); function allowDaoFund() external; function daoFundAllowed() external view returns (bool); function addUserAmount(address user, uint256 amount) external; function subUserAmount(address user, uint256 amount) external; function claim() external; }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.20; interface INukeFund { // Events for logging contract activities event FundBalanceUpdated(uint256 newBalance); event FundReceived(address indexed from, uint256 amount); event Nuked( address indexed owner, uint256 indexed tokenId, uint256 nukeAmount ); event DevShareDistributed(uint256 devShare); event TraitForgeNftAddressUpdated(address indexed newAddress); event AirdropAddressUpdated(address indexed newAddress); event DevAddressUpdated(address indexed newAddress); event DaoAddressUpdated(address indexed newAddress); // Fallback function to receive ETH and update fund balance receive() external payable; function setTaxCut(uint256 _taxCut) external; function setMinimumDaysHeld(uint256 value) external; function setDefaultNukeFactorIncrease(uint256 value) external; function setMaxAllowedClaimDivisor(uint256 value) external; function setNukeFactorMaxParam(uint256 value) external; // Allow the owner to update the reference to the ERC721 contract function setTraitForgeNftContract(address _traitForgeNft) external; function setAirdropContract(address _airdrop) external; function setDevAddress(address payable account) external; function setDaoAddress(address payable account) external; // View function to see the current balance of the fund function getFundBalance() external view returns (uint256); // Calculate the age of a token based on its creation timestamp and current time function calculateAge(uint256 tokenId) external view returns (uint256); // Calculate the nuke factor of a token, which affects the claimable amount from the fund function calculateNukeFactor(uint256 tokenId) external view returns (uint256); function nuke(uint256 tokenId) external; function canTokenBeNuked(uint256 tokenId) external view returns (bool); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.20; import '@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol'; interface ITraitForgeNft is IERC721Enumerable { // Events for logging contract activities event Minted( address indexed minter, uint256 indexed itemId, uint256 indexed generation, uint256 entropyValue, uint256 mintPrice ); event NewEntityMinted( address indexed owner, uint256 indexed tokenId, uint256 indexed generation, uint256 entropy ); event GenerationIncremented(uint256 newGeneration); event FundsDistributedToNukeFund(address indexed to, uint256 amount); event NukeFundContractUpdated(address nukeFundAddress); function setNukeFundContract(address payable _nukeFundAddress) external; function setEntityForgingContract(address _entityForgingAddress) external; function setEntropyGenerator(address _entropyGeneratorAddress) external; function setAirdropContract(address _airdrop) external; function setStartPrice(uint256 _startPrice) external; function setPriceIncrement(uint256 _priceIncrement) external; function startAirdrop(uint256 amount) external; function isApprovedOrOwner( address spender, uint256 tokenId ) external view returns (bool); function burn(uint256 tokenId) external; function forge( address newOwner, uint256 parent1Id, uint256 parent2Id, string memory baseTokenURI ) external returns (uint256); function mintToken(bytes32[] calldata proof) external payable; function mintWithBudget(bytes32[] calldata proof) external payable; function calculateMintPrice() external view returns (uint256); function getTokenEntropy(uint256 tokenId) external view returns (uint256); function getTokenGeneration(uint256 tokenId) external view returns (uint256); function getEntropiesForTokens( uint256 forgerTokenId, uint256 mergerTokenId ) external view returns (uint256 forgerEntropy, uint256 mergerEntropy); function getTokenAge(uint256 tokenId) external view returns (uint256); function getTokenCreationTimestamp( uint256 tokenId ) external view returns (uint256); function isForger(uint256 tokenId) external view returns (bool); }
{ "optimizer": { "enabled": true, "runs": 200 }, "evmVersion": "paris", "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract ABI
API[{"inputs":[{"internalType":"address","name":"_traitForgeNft","type":"address"},{"internalType":"address","name":"_airdrop","type":"address"},{"internalType":"address payable","name":"_devAddress","type":"address"},{"internalType":"address payable","name":"_daoAddress","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"AirdropAddressUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"DaoAddressUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"DevAddressUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"devShare","type":"uint256"}],"name":"DevShareDistributed","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"FundBalanceUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"FundReceived","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"nukeAmount","type":"uint256"}],"name":"Nuked","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":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"TraitForgeNftAddressUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"MAX_DENOMINATOR","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ageMultiplier","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"airdropContract","outputs":[{"internalType":"contract IAirdrop","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"calculateAge","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"calculateNukeFactor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"canTokenBeNuked","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"daoAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"defaultNukeFactorIncrease","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"devAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getAgeMultiplier","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getFundBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxAllowedClaimDivisor","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumDaysHeld","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nftContract","outputs":[{"internalType":"contract ITraitForgeNft","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"nuke","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"nukeFactorMaxParam","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_ageMultiplier","type":"uint256"}],"name":"setAgeMultplier","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_airdrop","type":"address"}],"name":"setAirdropContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"setDaoAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setDefaultNukeFactorIncrease","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"setDevAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setMaxAllowedClaimDivisor","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setMinimumDaysHeld","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setNukeFactorMaxParam","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_taxCut","type":"uint256"}],"name":"setTaxCut","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_traitForgeNft","type":"address"}],"name":"setTraitForgeNftContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"taxCut","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
6080604052600a60075560fa60085560026009556002620186a062000025919062000122565b600a556203f480600b553480156200003c57600080fd5b506040516200192d3803806200192d8339810160408190526200005f916200015e565b60016000556200006f33620000d0565b6001805460ff60a01b19169055600380546001600160a01b039586166001600160a01b0319918216179091556004805494861694821694909417909355600580549285169284169290921790915560068054919093169116179055620001c6565b600180546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6000826200014057634e487b7160e01b600052601260045260246000fd5b500490565b6001600160a01b03811681146200015b57600080fd5b50565b600080600080608085870312156200017557600080fd5b8451620001828162000145565b6020860151909450620001958162000145565b6040860151909350620001a88162000145565b6060860151909250620001bb8162000145565b939692955090935050565b61175780620001d66000396000f3fe6080604052600436106101dc5760003560e01c806385cc8bfb11610102578063d0d41fe111610095578063e2c29da811610064578063e2c29da81461089c578063f17d1534146108bc578063f2fde38b146108d2578063fca1ceb8146108f257600080fd5b8063d0d41fe114610832578063d56d229d14610852578063dae9e37914610872578063df0b79ab1461088757600080fd5b80639d1e39bb116100d15780639d1e39bb146107c6578063ab2be726146107dc578063c023eed6146107fc578063c8f640851461081c57600080fd5b806385cc8bfb146107485780638802e47e146107685780638da5cb5b146107885780639a3cac6a146107a657600080fd5b8063415bbca81161017a5780636f011538116101495780636f011538146106dc578063715018a6146106fc5780637637de841461071157806381d189f21461073157600080fd5b8063415bbca814610671578063562e99c0146106875780635c448e9a146106a75780635c975abb146106bd57600080fd5b806324c2c1a4116101b657806324c2c1a4146105d35780632c7485d0146106015780633ad10ef6146106315780633f04777b1461065157600080fd5b80630d95508d146105545780631ccf1be5146105765780632131c68c1461059657600080fd5b3661054f576000600754346101f19190611597565b905060006101ff82346115ab565b9050806002600082825461021391906115c4565b9091555050600480546040805163143c2a3160e01b815290516001600160a01b039092169263143c2a319282820192602092908290030181865afa15801561025f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061028391906115d7565b61033c576005546040516000916001600160a01b03169084908381818185875af1925050503d80600081146102d4576040519150601f19603f3d011682016040523d82523d6000602084013e6102d9565b606091505b50509050806103035760405162461bcd60e51b81526004016102fa90611600565b60405180910390fd5b6040518381527ffee0367062ca5946b3092f4b8c56c0a74633ed16ed153e34a63ed9333edf4e499060200160405180910390a1506104dd565b6004805460408051637a14eddb60e01b815290516001600160a01b0390921692637a14eddb9282820192602092908290030181865afa158015610383573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103a791906115d7565b6104355760006103bf6001546001600160a01b031690565b6001600160a01b03168360405160006040518083038185875af1925050503d8060008114610409576040519150601f19603f3d011682016040523d82523d6000602084013e61040e565b606091505b505090508061042f5760405162461bcd60e51b81526004016102fa90611600565b506104dd565b6006546040516000916001600160a01b03169084908381818185875af1925050503d8060008114610482576040519150601f19603f3d011682016040523d82523d6000602084013e610487565b606091505b50509050806104a85760405162461bcd60e51b81526004016102fa90611600565b6040518381527ffee0367062ca5946b3092f4b8c56c0a74633ed16ed153e34a63ed9333edf4e499060200160405180910390a1505b60405134815233907f54a5b8782470a0d2c022b3b9e5e729503ac5dbdfe053afeb4559f9297f7565a69060200160405180910390a27f1c12d443904f86e97d1a2e676cef66e79b25b1d1f6eb270c0a700526edf9b18260025460405161054591815260200190565b60405180910390a1005b600080fd5b34801561056057600080fd5b5061057461056f366004611629565b610908565b005b34801561058257600080fd5b50610574610591366004611629565b610d72565b3480156105a257600080fd5b506006546105b6906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156105df57600080fd5b506105f36105ee366004611629565b610d7f565b6040519081526020016105ca565b34801561060d57600080fd5b5061062161061c366004611629565b610ed6565b60405190151581526020016105ca565b34801561063d57600080fd5b506005546105b6906001600160a01b031681565b34801561065d57600080fd5b5061057461066c366004611629565b610fe8565b34801561067d57600080fd5b506105f360085481565b34801561069357600080fd5b506105746106a2366004611657565b610ff5565b3480156106b357600080fd5b506105f360075481565b3480156106c957600080fd5b50600154600160a01b900460ff16610621565b3480156106e857600080fd5b506105746106f7366004611657565b611047565b34801561070857600080fd5b50610574611099565b34801561071d57600080fd5b5061057461072c366004611629565b6110ad565b34801561073d57600080fd5b506105f3620186a081565b34801561075457600080fd5b506105f3610763366004611629565b6110ba565b34801561077457600080fd5b50610574610783366004611629565b6112d8565b34801561079457600080fd5b506001546001600160a01b03166105b6565b3480156107b257600080fd5b506105746107c1366004611657565b6112e5565b3480156107d257600080fd5b506105f3600a5481565b3480156107e857600080fd5b506004546105b6906001600160a01b031681565b34801561080857600080fd5b50610574610817366004611629565b611337565b34801561082857600080fd5b506105f3600b5481565b34801561083e57600080fd5b5061057461084d366004611657565b611344565b34801561085e57600080fd5b506003546105b6906001600160a01b031681565b34801561087e57600080fd5b506002546105f3565b34801561089357600080fd5b50600c546105f3565b3480156108a857600080fd5b506105746108b7366004611629565b611396565b3480156108c857600080fd5b506105f3600c5481565b3480156108de57600080fd5b506105746108ed366004611657565b6113a3565b3480156108fe57600080fd5b506105f360095481565b610910611419565b610918611466565b60035460405163430c208160e01b8152336004820152602481018390526001600160a01b039091169063430c208190604401602060405180830381865afa158015610967573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061098b91906115d7565b6109ed5760405162461bcd60e51b815260206004820152602d60248201527f4552433732313a2063616c6c6572206973206e6f7420746f6b656e206f776e6560448201526c1c881bdc88185c1c1c9bdd9959609a1b60648201526084016102fa565b60035460405163020604bf60e21b81526004810183905230916001600160a01b03169063081812fc90602401602060405180830381865afa158015610a36573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a5a9190611674565b6001600160a01b03161480610adc575060035460405163e985e9c560e01b81523360048201523060248201526001600160a01b039091169063e985e9c590604401602060405180830381865afa158015610ab8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610adc91906115d7565b610b3f5760405162461bcd60e51b815260206004820152602e60248201527f436f6e7472616374206d75737420626520617070726f76656420746f2074726160448201526d3739b332b9103a34329027232a1760911b60648201526084016102fa565b610b4881610ed6565b610b945760405162461bcd60e51b815260206004820152601760248201527f546f6b656e206973206e6f74206d61747572652079657400000000000000000060448201526064016102fa565b6000610b9f82610d7f565b90506000620186a082600254610bb59190611691565b610bbf9190611597565b90506000600954600254610bd39190611597565b90506000600a548411610be65782610be8565b815b90508060026000828254610bfc91906115ab565b9091555050600354604051630852cd8d60e31b8152600481018790526001600160a01b03909116906342966c6890602401600060405180830381600087803b158015610c4757600080fd5b505af1158015610c5b573d6000803e3d6000fd5b50506040516000925033915083908381818185875af1925050503d8060008114610ca1576040519150601f19603f3d011682016040523d82523d6000602084013e610ca6565b606091505b5050905080610cee5760405162461bcd60e51b81526020600482015260146024820152732330b4b632b2103a379039b2b7321022ba3432b960611b60448201526064016102fa565b604051828152869033907f8c9149f14ad96a26724a68fd0cc1d0ed43cdbf7e29d39c7857ca4c1d5b5a864d9060200160405180910390a37f1c12d443904f86e97d1a2e676cef66e79b25b1d1f6eb270c0a700526edf9b182600254604051610d5891815260200190565b60405180910390a15050505050610d6f6001600055565b50565b610d7a6114bf565b600855565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610dcd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df19190611674565b6001600160a01b031603610e175760405162461bcd60e51b81526004016102fa906116a8565b6003546040516306b6c00b60e01b8152600481018490526000916001600160a01b0316906306b6c00b90602401602060405180830381865afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e8591906116f4565b90506000610e92846110ba565b90506000610ea1602884611597565b9050600081620186a060085485610eb89190611691565b610ec29190611597565b610ecc91906115c4565b9695505050505050565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610f24573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f489190611674565b6001600160a01b031603610f6e5760405162461bcd60e51b81526004016102fa906116a8565b600354604051630b30fec360e41b8152600481018490526000916001600160a01b03169063b30fec3090602401602060405180830381865afa158015610fb8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610fdc91906116f4565b600b5411159392505050565b610ff06114bf565b600a55565b610ffd6114bf565b600380546001600160a01b0319166001600160a01b0383169081179091556040517fcf5226c92f5621f29c0e7a9e9d259703b3f6013f572ab91a786bdad05ee4a69d90600090a250565b61104f6114bf565b600480546001600160a01b0319166001600160a01b0383169081179091556040517f0bea07ef1c025671eaeea51d013aed8e48d9427504fe445a03262549abc96b9790600090a250565b6110a16114bf565b6110ab6000611519565b565b6110b56114bf565b600955565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015611108573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061112c9190611674565b6001600160a01b0316036111795760405162461bcd60e51b8152602060048201526014602482015273151bdad95b88191bd95cc81b9bdd08195e1a5cdd60621b60448201526064016102fa565b60035460405163431a3f9d60e01b815260048101849052600091601891603c9182916001600160a01b039091169063431a3f9d90602401602060405180830381865afa1580156111cd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111f191906116f4565b6111fb90426115ab565b6112059190611597565b61120f9190611597565b6112199190611597565b6003546040516306b6c00b60e01b815260048101869052919250600091600a916001600160a01b0316906306b6c00b90602401602060405180830381865afa158015611269573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061128d91906116f4565b611297919061170d565b9050600061016d600c54620186a084866112b19190611691565b6112bb9190611691565b6112c59190611691565b6112cf9190611597565b95945050505050565b6112e06114bf565b600c55565b6112ed6114bf565b600680546001600160a01b0319166001600160a01b0383169081179091556040517fc995b82ab98c255e9e917cdc60bde29d326b5242f499b6aa453e3ef95fc4f6ef90600090a250565b61133f6114bf565b600755565b61134c6114bf565b600580546001600160a01b0319166001600160a01b0383169081179091556040517f34830ecd12aee38e030de8db2aab7662959ba614a8af53e095041d13deced11d90600090a250565b61139e6114bf565b600b55565b6113ab6114bf565b6001600160a01b0381166114105760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016102fa565b610d6f81611519565b600154600160a01b900460ff16156110ab5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016102fa565b6002600054036114b85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016102fa565b6002600055565b6001546001600160a01b031633146110ab5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016102fa565b600180546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000826115a6576115a661156b565b500490565b818103818111156115be576115be611581565b92915050565b808201808211156115be576115be611581565b6000602082840312156115e957600080fd5b815180151581146115f957600080fd5b9392505050565b6020808252600f908201526e115512081cd95b990819985a5b1959608a1b604082015260600190565b60006020828403121561163b57600080fd5b5035919050565b6001600160a01b0381168114610d6f57600080fd5b60006020828403121561166957600080fd5b81356115f981611642565b60006020828403121561168657600080fd5b81516115f981611642565b80820281158282048414176115be576115be611581565b6020808252602c908201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860408201526b34b9ba32b73a103a37b5b2b760a11b606082015260800190565b60006020828403121561170657600080fd5b5051919050565b60008261171c5761171c61156b565b50069056fea26469706673582212209af17f076ae6fd4e2902dae74eddfac5270c7f98ede40b24fb9548cd40ff3edb64736f6c63430008140033000000000000000000000000587f1dcfccd7ca9c1b163a1b98bdf652c7f43eb700000000000000000000000033bc3db25889641a3a389c0232bdb692928d475c00000000000000000000000039051d67f02ed5888fe196d2f446f5aa263de04400000000000000000000000004680ee660ce101ed21c028000090fbe1f6fddb0
Deployed Bytecode
0x6080604052600436106101dc5760003560e01c806385cc8bfb11610102578063d0d41fe111610095578063e2c29da811610064578063e2c29da81461089c578063f17d1534146108bc578063f2fde38b146108d2578063fca1ceb8146108f257600080fd5b8063d0d41fe114610832578063d56d229d14610852578063dae9e37914610872578063df0b79ab1461088757600080fd5b80639d1e39bb116100d15780639d1e39bb146107c6578063ab2be726146107dc578063c023eed6146107fc578063c8f640851461081c57600080fd5b806385cc8bfb146107485780638802e47e146107685780638da5cb5b146107885780639a3cac6a146107a657600080fd5b8063415bbca81161017a5780636f011538116101495780636f011538146106dc578063715018a6146106fc5780637637de841461071157806381d189f21461073157600080fd5b8063415bbca814610671578063562e99c0146106875780635c448e9a146106a75780635c975abb146106bd57600080fd5b806324c2c1a4116101b657806324c2c1a4146105d35780632c7485d0146106015780633ad10ef6146106315780633f04777b1461065157600080fd5b80630d95508d146105545780631ccf1be5146105765780632131c68c1461059657600080fd5b3661054f576000600754346101f19190611597565b905060006101ff82346115ab565b9050806002600082825461021391906115c4565b9091555050600480546040805163143c2a3160e01b815290516001600160a01b039092169263143c2a319282820192602092908290030181865afa15801561025f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061028391906115d7565b61033c576005546040516000916001600160a01b03169084908381818185875af1925050503d80600081146102d4576040519150601f19603f3d011682016040523d82523d6000602084013e6102d9565b606091505b50509050806103035760405162461bcd60e51b81526004016102fa90611600565b60405180910390fd5b6040518381527ffee0367062ca5946b3092f4b8c56c0a74633ed16ed153e34a63ed9333edf4e499060200160405180910390a1506104dd565b6004805460408051637a14eddb60e01b815290516001600160a01b0390921692637a14eddb9282820192602092908290030181865afa158015610383573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103a791906115d7565b6104355760006103bf6001546001600160a01b031690565b6001600160a01b03168360405160006040518083038185875af1925050503d8060008114610409576040519150601f19603f3d011682016040523d82523d6000602084013e61040e565b606091505b505090508061042f5760405162461bcd60e51b81526004016102fa90611600565b506104dd565b6006546040516000916001600160a01b03169084908381818185875af1925050503d8060008114610482576040519150601f19603f3d011682016040523d82523d6000602084013e610487565b606091505b50509050806104a85760405162461bcd60e51b81526004016102fa90611600565b6040518381527ffee0367062ca5946b3092f4b8c56c0a74633ed16ed153e34a63ed9333edf4e499060200160405180910390a1505b60405134815233907f54a5b8782470a0d2c022b3b9e5e729503ac5dbdfe053afeb4559f9297f7565a69060200160405180910390a27f1c12d443904f86e97d1a2e676cef66e79b25b1d1f6eb270c0a700526edf9b18260025460405161054591815260200190565b60405180910390a1005b600080fd5b34801561056057600080fd5b5061057461056f366004611629565b610908565b005b34801561058257600080fd5b50610574610591366004611629565b610d72565b3480156105a257600080fd5b506006546105b6906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156105df57600080fd5b506105f36105ee366004611629565b610d7f565b6040519081526020016105ca565b34801561060d57600080fd5b5061062161061c366004611629565b610ed6565b60405190151581526020016105ca565b34801561063d57600080fd5b506005546105b6906001600160a01b031681565b34801561065d57600080fd5b5061057461066c366004611629565b610fe8565b34801561067d57600080fd5b506105f360085481565b34801561069357600080fd5b506105746106a2366004611657565b610ff5565b3480156106b357600080fd5b506105f360075481565b3480156106c957600080fd5b50600154600160a01b900460ff16610621565b3480156106e857600080fd5b506105746106f7366004611657565b611047565b34801561070857600080fd5b50610574611099565b34801561071d57600080fd5b5061057461072c366004611629565b6110ad565b34801561073d57600080fd5b506105f3620186a081565b34801561075457600080fd5b506105f3610763366004611629565b6110ba565b34801561077457600080fd5b50610574610783366004611629565b6112d8565b34801561079457600080fd5b506001546001600160a01b03166105b6565b3480156107b257600080fd5b506105746107c1366004611657565b6112e5565b3480156107d257600080fd5b506105f3600a5481565b3480156107e857600080fd5b506004546105b6906001600160a01b031681565b34801561080857600080fd5b50610574610817366004611629565b611337565b34801561082857600080fd5b506105f3600b5481565b34801561083e57600080fd5b5061057461084d366004611657565b611344565b34801561085e57600080fd5b506003546105b6906001600160a01b031681565b34801561087e57600080fd5b506002546105f3565b34801561089357600080fd5b50600c546105f3565b3480156108a857600080fd5b506105746108b7366004611629565b611396565b3480156108c857600080fd5b506105f3600c5481565b3480156108de57600080fd5b506105746108ed366004611657565b6113a3565b3480156108fe57600080fd5b506105f360095481565b610910611419565b610918611466565b60035460405163430c208160e01b8152336004820152602481018390526001600160a01b039091169063430c208190604401602060405180830381865afa158015610967573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061098b91906115d7565b6109ed5760405162461bcd60e51b815260206004820152602d60248201527f4552433732313a2063616c6c6572206973206e6f7420746f6b656e206f776e6560448201526c1c881bdc88185c1c1c9bdd9959609a1b60648201526084016102fa565b60035460405163020604bf60e21b81526004810183905230916001600160a01b03169063081812fc90602401602060405180830381865afa158015610a36573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a5a9190611674565b6001600160a01b03161480610adc575060035460405163e985e9c560e01b81523360048201523060248201526001600160a01b039091169063e985e9c590604401602060405180830381865afa158015610ab8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610adc91906115d7565b610b3f5760405162461bcd60e51b815260206004820152602e60248201527f436f6e7472616374206d75737420626520617070726f76656420746f2074726160448201526d3739b332b9103a34329027232a1760911b60648201526084016102fa565b610b4881610ed6565b610b945760405162461bcd60e51b815260206004820152601760248201527f546f6b656e206973206e6f74206d61747572652079657400000000000000000060448201526064016102fa565b6000610b9f82610d7f565b90506000620186a082600254610bb59190611691565b610bbf9190611597565b90506000600954600254610bd39190611597565b90506000600a548411610be65782610be8565b815b90508060026000828254610bfc91906115ab565b9091555050600354604051630852cd8d60e31b8152600481018790526001600160a01b03909116906342966c6890602401600060405180830381600087803b158015610c4757600080fd5b505af1158015610c5b573d6000803e3d6000fd5b50506040516000925033915083908381818185875af1925050503d8060008114610ca1576040519150601f19603f3d011682016040523d82523d6000602084013e610ca6565b606091505b5050905080610cee5760405162461bcd60e51b81526020600482015260146024820152732330b4b632b2103a379039b2b7321022ba3432b960611b60448201526064016102fa565b604051828152869033907f8c9149f14ad96a26724a68fd0cc1d0ed43cdbf7e29d39c7857ca4c1d5b5a864d9060200160405180910390a37f1c12d443904f86e97d1a2e676cef66e79b25b1d1f6eb270c0a700526edf9b182600254604051610d5891815260200190565b60405180910390a15050505050610d6f6001600055565b50565b610d7a6114bf565b600855565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610dcd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df19190611674565b6001600160a01b031603610e175760405162461bcd60e51b81526004016102fa906116a8565b6003546040516306b6c00b60e01b8152600481018490526000916001600160a01b0316906306b6c00b90602401602060405180830381865afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e8591906116f4565b90506000610e92846110ba565b90506000610ea1602884611597565b9050600081620186a060085485610eb89190611691565b610ec29190611597565b610ecc91906115c4565b9695505050505050565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610f24573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f489190611674565b6001600160a01b031603610f6e5760405162461bcd60e51b81526004016102fa906116a8565b600354604051630b30fec360e41b8152600481018490526000916001600160a01b03169063b30fec3090602401602060405180830381865afa158015610fb8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610fdc91906116f4565b600b5411159392505050565b610ff06114bf565b600a55565b610ffd6114bf565b600380546001600160a01b0319166001600160a01b0383169081179091556040517fcf5226c92f5621f29c0e7a9e9d259703b3f6013f572ab91a786bdad05ee4a69d90600090a250565b61104f6114bf565b600480546001600160a01b0319166001600160a01b0383169081179091556040517f0bea07ef1c025671eaeea51d013aed8e48d9427504fe445a03262549abc96b9790600090a250565b6110a16114bf565b6110ab6000611519565b565b6110b56114bf565b600955565b6003546040516331a9108f60e11b81526004810183905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015611108573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061112c9190611674565b6001600160a01b0316036111795760405162461bcd60e51b8152602060048201526014602482015273151bdad95b88191bd95cc81b9bdd08195e1a5cdd60621b60448201526064016102fa565b60035460405163431a3f9d60e01b815260048101849052600091601891603c9182916001600160a01b039091169063431a3f9d90602401602060405180830381865afa1580156111cd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111f191906116f4565b6111fb90426115ab565b6112059190611597565b61120f9190611597565b6112199190611597565b6003546040516306b6c00b60e01b815260048101869052919250600091600a916001600160a01b0316906306b6c00b90602401602060405180830381865afa158015611269573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061128d91906116f4565b611297919061170d565b9050600061016d600c54620186a084866112b19190611691565b6112bb9190611691565b6112c59190611691565b6112cf9190611597565b95945050505050565b6112e06114bf565b600c55565b6112ed6114bf565b600680546001600160a01b0319166001600160a01b0383169081179091556040517fc995b82ab98c255e9e917cdc60bde29d326b5242f499b6aa453e3ef95fc4f6ef90600090a250565b61133f6114bf565b600755565b61134c6114bf565b600580546001600160a01b0319166001600160a01b0383169081179091556040517f34830ecd12aee38e030de8db2aab7662959ba614a8af53e095041d13deced11d90600090a250565b61139e6114bf565b600b55565b6113ab6114bf565b6001600160a01b0381166114105760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016102fa565b610d6f81611519565b600154600160a01b900460ff16156110ab5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016102fa565b6002600054036114b85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016102fa565b6002600055565b6001546001600160a01b031633146110ab5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016102fa565b600180546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000826115a6576115a661156b565b500490565b818103818111156115be576115be611581565b92915050565b808201808211156115be576115be611581565b6000602082840312156115e957600080fd5b815180151581146115f957600080fd5b9392505050565b6020808252600f908201526e115512081cd95b990819985a5b1959608a1b604082015260600190565b60006020828403121561163b57600080fd5b5035919050565b6001600160a01b0381168114610d6f57600080fd5b60006020828403121561166957600080fd5b81356115f981611642565b60006020828403121561168657600080fd5b81516115f981611642565b80820281158282048414176115be576115be611581565b6020808252602c908201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860408201526b34b9ba32b73a103a37b5b2b760a11b606082015260800190565b60006020828403121561170657600080fd5b5051919050565b60008261171c5761171c61156b565b50069056fea26469706673582212209af17f076ae6fd4e2902dae74eddfac5270c7f98ede40b24fb9548cd40ff3edb64736f6c63430008140033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000587f1dcfccd7ca9c1b163a1b98bdf652c7f43eb700000000000000000000000033bc3db25889641a3a389c0232bdb692928d475c00000000000000000000000039051d67f02ed5888fe196d2f446f5aa263de04400000000000000000000000004680ee660ce101ed21c028000090fbe1f6fddb0
-----Decoded View---------------
Arg [0] : _traitForgeNft (address): 0x587f1DCfcCD7Ca9c1b163a1B98bdf652c7F43Eb7
Arg [1] : _airdrop (address): 0x33BC3DB25889641A3A389C0232BdB692928D475C
Arg [2] : _devAddress (address): 0x39051d67f02eD5888FE196d2F446F5aa263dE044
Arg [3] : _daoAddress (address): 0x04680EE660Ce101ed21c028000090fbE1F6FDDb0
-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 000000000000000000000000587f1dcfccd7ca9c1b163a1b98bdf652c7f43eb7
Arg [1] : 00000000000000000000000033bc3db25889641a3a389c0232bdb692928d475c
Arg [2] : 00000000000000000000000039051d67f02ed5888fe196d2f446f5aa263de044
Arg [3] : 00000000000000000000000004680ee660ce101ed21c028000090fbe1f6fddb0
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.