Overview
ETH Balance
ETH Value
$0.00More Info
Private Name Tags
ContractCreator
Loading...
Loading
Contract Name:
ScrollZNSBadge
Compiler Version
v0.8.19+commit.7dd6d404
Optimization Enabled:
Yes with 200 runs
Other Settings:
paris EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; import {ScrollBadge} from "../ScrollBadge.sol"; import {ScrollBadgeSelfAttest} from "../extensions/ScrollBadgeSelfAttest.sol"; import {ScrollBadgeEligibilityCheck} from "../extensions/ScrollBadgeEligibilityCheck.sol"; import {ScrollBadgeSingleton} from "../extensions/ScrollBadgeSingleton.sol"; import {Unauthorized} from "../../Errors.sol"; import {IERC721} from "@openzeppelin/contracts/token/ERC721/IERC721.sol"; /// @title ScrollZNSBadge /// @notice A badge that shows if the user owns a ZNS Domain contract ScrollZNSBadge is ScrollBadgeSelfAttest, ScrollBadgeEligibilityCheck, ScrollBadgeSingleton { address public ZNSRegistry; string public tokenURI; constructor(address resolver_, address _registry, string memory _tokenURI) ScrollBadge(resolver_) { ZNSRegistry = _registry; tokenURI = _tokenURI; } /// @inheritdoc ScrollBadge function onIssueBadge( Attestation calldata attestation ) internal override(ScrollBadge, ScrollBadgeSelfAttest, ScrollBadgeSingleton) returns (bool) { if (!super.onIssueBadge(attestation)) { return false; } if (IERC721(ZNSRegistry).balanceOf(attestation.recipient) == 0) { revert Unauthorized(); } return true; } /// @inheritdoc ScrollBadge function onRevokeBadge( Attestation calldata attestation ) internal override(ScrollBadge, ScrollBadgeSelfAttest, ScrollBadgeSingleton) returns (bool) { if (!super.onRevokeBadge(attestation)) { return false; } return true; } /// @inheritdoc ScrollBadgeEligibilityCheck function isEligible(address recipient) external view override returns (bool) { return !hasBadge(recipient) && IERC721(ZNSRegistry).balanceOf(recipient) > 0; } /// @inheritdoc ScrollBadge function badgeTokenURI(bytes32 /*uid*/) public view override returns (string memory) { return tokenURI; } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; import { ISchemaRegistry } from "./ISchemaRegistry.sol"; import { ISemver } from "./ISemver.sol"; import { Attestation, Signature } from "./Common.sol"; /// @notice A struct representing the arguments of the attestation request. struct AttestationRequestData { address recipient; // The recipient of the attestation. uint64 expirationTime; // The time when the attestation expires (Unix timestamp). bool revocable; // Whether the attestation is revocable. bytes32 refUID; // The UID of the related attestation. bytes data; // Custom attestation data. uint256 value; // An explicit ETH amount to send to the resolver. This is important to prevent accidental user errors. } /// @notice A struct representing the full arguments of the attestation request. struct AttestationRequest { bytes32 schema; // The unique identifier of the schema. AttestationRequestData data; // The arguments of the attestation request. } /// @notice A struct representing the full arguments of the full delegated attestation request. struct DelegatedAttestationRequest { bytes32 schema; // The unique identifier of the schema. AttestationRequestData data; // The arguments of the attestation request. Signature signature; // The ECDSA signature data. address attester; // The attesting account. uint64 deadline; // The deadline of the signature/request. } /// @notice A struct representing the full arguments of the multi attestation request. struct MultiAttestationRequest { bytes32 schema; // The unique identifier of the schema. AttestationRequestData[] data; // The arguments of the attestation request. } /// @notice A struct representing the full arguments of the delegated multi attestation request. struct MultiDelegatedAttestationRequest { bytes32 schema; // The unique identifier of the schema. AttestationRequestData[] data; // The arguments of the attestation requests. Signature[] signatures; // The ECDSA signatures data. Please note that the signatures are assumed to be signed with increasing nonces. address attester; // The attesting account. uint64 deadline; // The deadline of the signature/request. } /// @notice A struct representing the arguments of the revocation request. struct RevocationRequestData { bytes32 uid; // The UID of the attestation to revoke. uint256 value; // An explicit ETH amount to send to the resolver. This is important to prevent accidental user errors. } /// @notice A struct representing the full arguments of the revocation request. struct RevocationRequest { bytes32 schema; // The unique identifier of the schema. RevocationRequestData data; // The arguments of the revocation request. } /// @notice A struct representing the arguments of the full delegated revocation request. struct DelegatedRevocationRequest { bytes32 schema; // The unique identifier of the schema. RevocationRequestData data; // The arguments of the revocation request. Signature signature; // The ECDSA signature data. address revoker; // The revoking account. uint64 deadline; // The deadline of the signature/request. } /// @notice A struct representing the full arguments of the multi revocation request. struct MultiRevocationRequest { bytes32 schema; // The unique identifier of the schema. RevocationRequestData[] data; // The arguments of the revocation request. } /// @notice A struct representing the full arguments of the delegated multi revocation request. struct MultiDelegatedRevocationRequest { bytes32 schema; // The unique identifier of the schema. RevocationRequestData[] data; // The arguments of the revocation requests. Signature[] signatures; // The ECDSA signatures data. Please note that the signatures are assumed to be signed with increasing nonces. address revoker; // The revoking account. uint64 deadline; // The deadline of the signature/request. } /// @title IEAS /// @notice EAS - Ethereum Attestation Service interface. interface IEAS is ISemver { /// @notice Emitted when an attestation has been made. /// @param recipient The recipient of the attestation. /// @param attester The attesting account. /// @param uid The UID the revoked attestation. /// @param schemaUID The UID of the schema. event Attested(address indexed recipient, address indexed attester, bytes32 uid, bytes32 indexed schemaUID); /// @notice Emitted when an attestation has been revoked. /// @param recipient The recipient of the attestation. /// @param attester The attesting account. /// @param schemaUID The UID of the schema. /// @param uid The UID the revoked attestation. event Revoked(address indexed recipient, address indexed attester, bytes32 uid, bytes32 indexed schemaUID); /// @notice Emitted when a data has been timestamped. /// @param data The data. /// @param timestamp The timestamp. event Timestamped(bytes32 indexed data, uint64 indexed timestamp); /// @notice Emitted when a data has been revoked. /// @param revoker The address of the revoker. /// @param data The data. /// @param timestamp The timestamp. event RevokedOffchain(address indexed revoker, bytes32 indexed data, uint64 indexed timestamp); /// @notice Returns the address of the global schema registry. /// @return The address of the global schema registry. function getSchemaRegistry() external view returns (ISchemaRegistry); /// @notice Attests to a specific schema. /// @param request The arguments of the attestation request. /// @return The UID of the new attestation. /// /// Example: /// attest({ /// schema: "0facc36681cbe2456019c1b0d1e7bedd6d1d40f6f324bf3dd3a4cef2999200a0", /// data: { /// recipient: "0xdEADBeAFdeAdbEafdeadbeafDeAdbEAFdeadbeaf", /// expirationTime: 0, /// revocable: true, /// refUID: "0x0000000000000000000000000000000000000000000000000000000000000000", /// data: "0xF00D", /// value: 0 /// } /// }) function attest(AttestationRequest calldata request) external payable returns (bytes32); /// @notice Attests to a specific schema via the provided ECDSA signature. /// @param delegatedRequest The arguments of the delegated attestation request. /// @return The UID of the new attestation. /// /// Example: /// attestByDelegation({ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: { /// recipient: '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', /// expirationTime: 1673891048, /// revocable: true, /// refUID: '0x0000000000000000000000000000000000000000000000000000000000000000', /// data: '0x1234', /// value: 0 /// }, /// signature: { /// v: 28, /// r: '0x148c...b25b', /// s: '0x5a72...be22' /// }, /// attester: '0xc5E8740aD971409492b1A63Db8d83025e0Fc427e', /// deadline: 1673891048 /// }) function attestByDelegation( DelegatedAttestationRequest calldata delegatedRequest ) external payable returns (bytes32); /// @notice Attests to multiple schemas. /// @param multiRequests The arguments of the multi attestation requests. The requests should be grouped by distinct /// schema ids to benefit from the best batching optimization. /// @return The UIDs of the new attestations. /// /// Example: /// multiAttest([{ /// schema: '0x33e9094830a5cba5554d1954310e4fbed2ef5f859ec1404619adea4207f391fd', /// data: [{ /// recipient: '0xdEADBeAFdeAdbEafdeadbeafDeAdbEAFdeadbeaf', /// expirationTime: 1673891048, /// revocable: true, /// refUID: '0x0000000000000000000000000000000000000000000000000000000000000000', /// data: '0x1234', /// value: 1000 /// }, /// { /// recipient: '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', /// expirationTime: 0, /// revocable: false, /// refUID: '0x480df4a039efc31b11bfdf491b383ca138b6bde160988222a2a3509c02cee174', /// data: '0x00', /// value: 0 /// }], /// }, /// { /// schema: '0x5ac273ce41e3c8bfa383efe7c03e54c5f0bff29c9f11ef6ffa930fc84ca32425', /// data: [{ /// recipient: '0xdEADBeAFdeAdbEafdeadbeafDeAdbEAFdeadbeaf', /// expirationTime: 0, /// revocable: true, /// refUID: '0x75bf2ed8dca25a8190c50c52db136664de25b2449535839008ccfdab469b214f', /// data: '0x12345678', /// value: 0 /// }, /// }]) function multiAttest(MultiAttestationRequest[] calldata multiRequests) external payable returns (bytes32[] memory); /// @notice Attests to multiple schemas using via provided ECDSA signatures. /// @param multiDelegatedRequests The arguments of the delegated multi attestation requests. The requests should be /// grouped by distinct schema ids to benefit from the best batching optimization. /// @return The UIDs of the new attestations. /// /// Example: /// multiAttestByDelegation([{ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: [{ /// recipient: '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', /// expirationTime: 1673891048, /// revocable: true, /// refUID: '0x0000000000000000000000000000000000000000000000000000000000000000', /// data: '0x1234', /// value: 0 /// }, /// { /// recipient: '0xdEADBeAFdeAdbEafdeadbeafDeAdbEAFdeadbeaf', /// expirationTime: 0, /// revocable: false, /// refUID: '0x0000000000000000000000000000000000000000000000000000000000000000', /// data: '0x00', /// value: 0 /// }], /// signatures: [{ /// v: 28, /// r: '0x148c...b25b', /// s: '0x5a72...be22' /// }, /// { /// v: 28, /// r: '0x487s...67bb', /// s: '0x12ad...2366' /// }], /// attester: '0x1D86495b2A7B524D747d2839b3C645Bed32e8CF4', /// deadline: 1673891048 /// }]) function multiAttestByDelegation( MultiDelegatedAttestationRequest[] calldata multiDelegatedRequests ) external payable returns (bytes32[] memory); /// @notice Revokes an existing attestation to a specific schema. /// @param request The arguments of the revocation request. /// /// Example: /// revoke({ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: { /// uid: '0x101032e487642ee04ee17049f99a70590c735b8614079fc9275f9dd57c00966d', /// value: 0 /// } /// }) function revoke(RevocationRequest calldata request) external payable; /// @notice Revokes an existing attestation to a specific schema via the provided ECDSA signature. /// @param delegatedRequest The arguments of the delegated revocation request. /// /// Example: /// revokeByDelegation({ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: { /// uid: '0xcbbc12102578c642a0f7b34fe7111e41afa25683b6cd7b5a14caf90fa14d24ba', /// value: 0 /// }, /// signature: { /// v: 27, /// r: '0xb593...7142', /// s: '0x0f5b...2cce' /// }, /// revoker: '0x244934dd3e31bE2c81f84ECf0b3E6329F5381992', /// deadline: 1673891048 /// }) function revokeByDelegation(DelegatedRevocationRequest calldata delegatedRequest) external payable; /// @notice Revokes existing attestations to multiple schemas. /// @param multiRequests The arguments of the multi revocation requests. The requests should be grouped by distinct /// schema ids to benefit from the best batching optimization. /// /// Example: /// multiRevoke([{ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: [{ /// uid: '0x211296a1ca0d7f9f2cfebf0daaa575bea9b20e968d81aef4e743d699c6ac4b25', /// value: 1000 /// }, /// { /// uid: '0xe160ac1bd3606a287b4d53d5d1d6da5895f65b4b4bab6d93aaf5046e48167ade', /// value: 0 /// }], /// }, /// { /// schema: '0x5ac273ce41e3c8bfa383efe7c03e54c5f0bff29c9f11ef6ffa930fc84ca32425', /// data: [{ /// uid: '0x053d42abce1fd7c8fcddfae21845ad34dae287b2c326220b03ba241bc5a8f019', /// value: 0 /// }, /// }]) function multiRevoke(MultiRevocationRequest[] calldata multiRequests) external payable; /// @notice Revokes existing attestations to multiple schemas via provided ECDSA signatures. /// @param multiDelegatedRequests The arguments of the delegated multi revocation attestation requests. The requests /// should be grouped by distinct schema ids to benefit from the best batching optimization. /// /// Example: /// multiRevokeByDelegation([{ /// schema: '0x8e72f5bc0a8d4be6aa98360baa889040c50a0e51f32dbf0baa5199bd93472ebc', /// data: [{ /// uid: '0x211296a1ca0d7f9f2cfebf0daaa575bea9b20e968d81aef4e743d699c6ac4b25', /// value: 1000 /// }, /// { /// uid: '0xe160ac1bd3606a287b4d53d5d1d6da5895f65b4b4bab6d93aaf5046e48167ade', /// value: 0 /// }], /// signatures: [{ /// v: 28, /// r: '0x148c...b25b', /// s: '0x5a72...be22' /// }, /// { /// v: 28, /// r: '0x487s...67bb', /// s: '0x12ad...2366' /// }], /// revoker: '0x244934dd3e31bE2c81f84ECf0b3E6329F5381992', /// deadline: 1673891048 /// }]) function multiRevokeByDelegation( MultiDelegatedRevocationRequest[] calldata multiDelegatedRequests ) external payable; /// @notice Timestamps the specified bytes32 data. /// @param data The data to timestamp. /// @return The timestamp the data was timestamped with. function timestamp(bytes32 data) external returns (uint64); /// @notice Timestamps the specified multiple bytes32 data. /// @param data The data to timestamp. /// @return The timestamp the data was timestamped with. function multiTimestamp(bytes32[] calldata data) external returns (uint64); /// @notice Revokes the specified bytes32 data. /// @param data The data to timestamp. /// @return The timestamp the data was revoked with. function revokeOffchain(bytes32 data) external returns (uint64); /// @notice Revokes the specified multiple bytes32 data. /// @param data The data to timestamp. /// @return The timestamp the data was revoked with. function multiRevokeOffchain(bytes32[] calldata data) external returns (uint64); /// @notice Returns an existing attestation by UID. /// @param uid The UID of the attestation to retrieve. /// @return The attestation data members. function getAttestation(bytes32 uid) external view returns (Attestation memory); /// @notice Checks whether an attestation exists. /// @param uid The UID of the attestation to retrieve. /// @return Whether an attestation exists. function isAttestationValid(bytes32 uid) external view returns (bool); /// @notice Returns the timestamp that the specified data was timestamped with. /// @param data The data to query. /// @return The timestamp the data was timestamped with. function getTimestamp(bytes32 data) external view returns (uint64); /// @notice Returns the timestamp that the specified data was timestamped with. /// @param data The data to query. /// @return The timestamp the data was timestamped with. function getRevokeOffchain(address revoker, bytes32 data) external view returns (uint64); }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; import {decodeBadgeData} from "../Common.sol"; import {IScrollBadge} from "../interfaces/IScrollBadge.sol"; import {IScrollBadgeResolver} from "../interfaces/IScrollBadgeResolver.sol"; import {AttestationBadgeMismatch, Unauthorized} from "../Errors.sol"; /// @title ScrollBadge /// @notice This contract implements the basic functionalities of a Scroll badge. /// It serves as the base contract for more complex badge functionalities. abstract contract ScrollBadge is IScrollBadge { // The global Scroll badge resolver contract. address public immutable resolver; // wallet address => badge count mapping(address => uint256) private _userBadgeCount; /// @dev Creates a new ScrollBadge instance. /// @param resolver_ The address of the global Scroll badge resolver contract. constructor(address resolver_) { resolver = resolver_; } /// @inheritdoc IScrollBadge function issueBadge(Attestation calldata attestation) public returns (bool) { // only callable from resolver if (msg.sender != address(resolver)) { revert Unauthorized(); } // delegate logic to subcontract if (!onIssueBadge(attestation)) { return false; } _userBadgeCount[attestation.recipient] += 1; emit IssueBadge(attestation.uid); return true; } /// @inheritdoc IScrollBadge function revokeBadge(Attestation calldata attestation) public returns (bool) { // only callable from resolver if (msg.sender != address(resolver)) { revert Unauthorized(); } // delegate logic to subcontract if (!onRevokeBadge(attestation)) { return false; } _userBadgeCount[attestation.recipient] -= 1; emit RevokeBadge(attestation.uid); return true; } /// @notice A resolver callback that should be implemented by child contracts. /// @param {attestation} The new attestation. /// @return Whether the attestation is valid. function onIssueBadge(Attestation calldata /*attestation*/ ) internal virtual returns (bool) { return true; } /// @notice A resolver callback that should be implemented by child contracts. /// @param {attestation} The existing attestation to be revoked. /// @return Whether the attestation can be revoked. function onRevokeBadge(Attestation calldata /*attestation*/ ) internal virtual returns (bool) { return true; } /// @inheritdoc IScrollBadge function getAndValidateBadge(bytes32 uid) public view returns (Attestation memory) { Attestation memory attestation = IScrollBadgeResolver(resolver).getAndValidateBadge(uid); (address badge,) = decodeBadgeData(attestation.data); if (badge != address(this)) { revert AttestationBadgeMismatch(uid); } return attestation; } /// @inheritdoc IScrollBadge function badgeTokenURI(bytes32 uid) public view virtual returns (string memory); /// @inheritdoc IScrollBadge function hasBadge(address user) public view virtual returns (bool) { return _userBadgeCount[user] > 0; } }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; import {ScrollBadge} from "../ScrollBadge.sol"; import {Unauthorized} from "../../Errors.sol"; /// @title ScrollBadgeSelfAttest /// @notice This contract ensures that only the badge recipient can attest. abstract contract ScrollBadgeSelfAttest is ScrollBadge { /// @inheritdoc ScrollBadge function onIssueBadge(Attestation calldata attestation) internal virtual override returns (bool) { if (!super.onIssueBadge(attestation)) { return false; } if (attestation.recipient != attestation.attester) { revert Unauthorized(); } return true; } /// @inheritdoc ScrollBadge function onRevokeBadge(Attestation calldata attestation) internal virtual override returns (bool) { return super.onRevokeBadge(attestation); } }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {ScrollBadge} from "../ScrollBadge.sol"; /// @title ScrollBadgeEligibilityCheck /// @notice This contract adds a standard on-chain eligibility check API. abstract contract ScrollBadgeEligibilityCheck is ScrollBadge { /// @notice Check if user is eligible to mint this badge. /// @param recipient The user's wallet address. /// @return Whether the user is eligible to mint. function isEligible(address recipient) external virtual returns (bool) { return !hasBadge(recipient); } }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; import {ScrollBadge} from "../ScrollBadge.sol"; import {SingletonBadge} from "../../Errors.sol"; /// @title ScrollBadgeSingleton /// @notice This contract only allows one active badge per wallet. abstract contract ScrollBadgeSingleton is ScrollBadge { /// @inheritdoc ScrollBadge function onIssueBadge(Attestation calldata attestation) internal virtual override returns (bool) { if (!super.onIssueBadge(attestation)) { return false; } if (hasBadge(attestation.recipient)) { revert SingletonBadge(); } return true; } /// @inheritdoc ScrollBadge function onRevokeBadge(Attestation calldata attestation) internal virtual override returns (bool) { return super.onRevokeBadge(attestation); } }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; error Unauthorized(); error CannotUpgrade(bytes32 uid); // attestation errors // note: these don't include the uid since it is not known prior to the attestation. error BadgeNotAllowed(address badge); error BadgeNotFound(address badge); error ExpirationDisabled(); error MissingPayload(); error ResolverPaymentsDisabled(); error RevocationDisabled(); error SingletonBadge(); error UnknownSchema(); // query errors error AttestationBadgeMismatch(bytes32 uid); error AttestationExpired(bytes32 uid); error AttestationNotFound(bytes32 uid); error AttestationOwnerMismatch(bytes32 uid); error AttestationRevoked(bytes32 uid); error AttestationSchemaMismatch(bytes32 uid); // profile errors error BadgeCountReached(); error LengthMismatch(); error TokenNotOwnedByUser(address token, uint256 tokenId); // profile registry errors error CallerIsNotUserProfile(); error DuplicatedUsername(); error ExpiredSignature(); error ImplementationNotContract(); error InvalidReferrer(); error InvalidSignature(); error InvalidUsername(); error MsgValueMismatchWithMintFee(); error ProfileAlreadyMinted();
// 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 pragma solidity ^0.8.0; import { ISemver } from "./ISemver.sol"; import { ISchemaResolver } from "./resolver/ISchemaResolver.sol"; /// @notice A struct representing a record for a submitted schema. struct SchemaRecord { bytes32 uid; // The unique identifier of the schema. ISchemaResolver resolver; // Optional schema resolver. bool revocable; // Whether the schema allows revocations explicitly. string schema; // Custom specification of the schema (e.g., an ABI). } /// @title ISchemaRegistry /// @notice The interface of global attestation schemas for the Ethereum Attestation Service protocol. interface ISchemaRegistry is ISemver { /// @notice Emitted when a new schema has been registered /// @param uid The schema UID. /// @param registerer The address of the account used to register the schema. /// @param schema The schema data. event Registered(bytes32 indexed uid, address indexed registerer, SchemaRecord schema); /// @notice Submits and reserves a new schema /// @param schema The schema data schema. /// @param resolver An optional schema resolver. /// @param revocable Whether the schema allows revocations explicitly. /// @return The UID of the new schema. function register(string calldata schema, ISchemaResolver resolver, bool revocable) external returns (bytes32); /// @notice Returns an existing schema by UID /// @param uid The UID of the schema to retrieve. /// @return The schema data members. function getSchema(bytes32 uid) external view returns (SchemaRecord memory); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; /// @title ISemver /// @notice A semver interface. interface ISemver { /// @notice Returns the full semver contract version. /// @return Semver contract version as a string. function version() external view returns (string memory); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; // A representation of an empty/uninitialized UID. bytes32 constant EMPTY_UID = 0; // A zero expiration represents an non-expiring attestation. uint64 constant NO_EXPIRATION_TIME = 0; error AccessDenied(); error DeadlineExpired(); error InvalidEAS(); error InvalidLength(); error InvalidSignature(); error NotFound(); /// @notice A struct representing ECDSA signature data. struct Signature { uint8 v; // The recovery ID. bytes32 r; // The x-coordinate of the nonce R. bytes32 s; // The signature data. } /// @notice A struct representing a single attestation. struct Attestation { bytes32 uid; // A unique identifier of the attestation. bytes32 schema; // The unique identifier of the schema. uint64 time; // The time when the attestation was created (Unix timestamp). uint64 expirationTime; // The time when the attestation expires (Unix timestamp). uint64 revocationTime; // The time when the attestation was revoked (Unix timestamp). bytes32 refUID; // The UID of the related attestation. address recipient; // The recipient of the attestation. address attester; // The attester/sender of the attestation. bool revocable; // Whether the attestation is revocable. bytes data; // Custom attestation data. } /// @notice A helper function to work with unchecked iterators in loops. function uncheckedInc(uint256 i) pure returns (uint256 j) { unchecked { j = i + 1; } }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; uint256 constant MAX_ATTACHED_BADGE_NUM = 48; string constant SCROLL_BADGE_SCHEMA = "address badge, bytes payload"; function decodeBadgeData(bytes memory data) pure returns (address, bytes memory) { return abi.decode(data, (address, bytes)); }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; interface IScrollBadge { event IssueBadge(bytes32 indexed uid); event RevokeBadge(bytes32 indexed uid); /// @notice A resolver callback invoked in the `issueBadge` function in the parent contract. /// @param attestation The new attestation. /// @return Whether the attestation is valid. function issueBadge(Attestation calldata attestation) external returns (bool); /// @notice A resolver callback invoked in the `revokeBadge` function in the parent contract. /// @param attestation The new attestation. /// @return Whether the attestation can be revoked. function revokeBadge(Attestation calldata attestation) external returns (bool); /// @notice Validate and return a Scroll badge attestation. /// @param uid The attestation UID. /// @return The attestation. function getAndValidateBadge(bytes32 uid) external view returns (Attestation memory); /// @notice Returns the token URI corresponding to a certain badge UID, or the default /// badge token URI if the pass UID is 0x0. /// @param uid The badge UID, or 0x0. /// @return The badge token URI (same format as ERC721). function badgeTokenURI(bytes32 uid) external view returns (string memory); /// @notice Returns true if the user has one or more of this badge. /// @param user The user's wallet address. /// @return True if the user has one or more of this badge. function hasBadge(address user) external view returns (bool); }
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; import {Attestation} from "@eas/contracts/IEAS.sol"; interface IScrollBadgeResolver { /** * * Events * * */ /// @dev Emitted when a new badge is issued. /// @param uid The UID of the new badge attestation. event IssueBadge(bytes32 indexed uid); /// @dev Emitted when a badge is revoked. /// @param uid The UID of the revoked badge attestation. event RevokeBadge(bytes32 indexed uid); /// @dev Emitted when the auto-attach status of a badge is updated. /// @param badge The address of the badge contract. /// @param enable Auto-attach was enabled if true, disabled if false. event UpdateAutoAttachWhitelist(address indexed badge, bool indexed enable); /** * * Public View Functions * * */ /// @notice Return the Scroll badge attestation schema. /// @return The GUID of the Scroll badge attestation schema. function schema() external returns (bytes32); /// @notice The profile registry contract. /// @return The address of the profile registry. function registry() external returns (address); /// @notice The global EAS contract. /// @return The address of the global EAS contract. function eas() external returns (address); /// @notice Validate and return a Scroll badge attestation. /// @param uid The attestation UID. /// @return The attestation. function getAndValidateBadge(bytes32 uid) external view returns (Attestation memory); }
// 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.0; import { ISemver } from "../ISemver.sol"; import { Attestation } from "../Common.sol"; /// @title ISchemaResolver /// @notice The interface of an optional schema resolver. interface ISchemaResolver is ISemver { /// @notice Checks if the resolver can be sent ETH. /// @return Whether the resolver supports ETH transfers. function isPayable() external pure returns (bool); /// @notice Processes an attestation and verifies whether it's valid. /// @param attestation The new attestation. /// @return Whether the attestation is valid. function attest(Attestation calldata attestation) external payable returns (bool); /// @notice Processes multiple attestations and verifies whether they are valid. /// @param attestations The new attestations. /// @param values Explicit ETH amounts which were sent with each attestation. /// @return Whether all the attestations are valid. function multiAttest( Attestation[] calldata attestations, uint256[] calldata values ) external payable returns (bool); /// @notice Processes an attestation revocation and verifies if it can be revoked. /// @param attestation The existing attestation to be revoked. /// @return Whether the attestation can be revoked. function revoke(Attestation calldata attestation) external payable returns (bool); /// @notice Processes revocation of multiple attestation and verifies they can be revoked. /// @param attestations The existing attestations to be revoked. /// @param values Explicit ETH amounts which were sent with each revocation. /// @return Whether the attestations can be revoked. function multiRevoke( Attestation[] calldata attestations, uint256[] calldata values ) external payable returns (bool); }
{ "remappings": [ "@eas/=node_modules/@ethereum-attestation-service/eas-contracts/", "@openzeppelin/=node_modules/@openzeppelin/", "solmate/=node_modules/solmate/src/", "ds-test/=lib/forge-std/lib/ds-test/src/", "forge-std/=lib/forge-std/src/" ], "optimizer": { "enabled": true, "runs": 200 }, "metadata": { "useLiteralContent": false, "bytecodeHash": "ipfs", "appendCBOR": true }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "evmVersion": "paris", "viaIR": false, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"address","name":"resolver_","type":"address"},{"internalType":"address","name":"_registry","type":"address"},{"internalType":"string","name":"_tokenURI","type":"string"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"bytes32","name":"uid","type":"bytes32"}],"name":"AttestationBadgeMismatch","type":"error"},{"inputs":[],"name":"SingletonBadge","type":"error"},{"inputs":[],"name":"Unauthorized","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"uid","type":"bytes32"}],"name":"IssueBadge","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"uid","type":"bytes32"}],"name":"RevokeBadge","type":"event"},{"inputs":[],"name":"ZNSRegistry","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"name":"badgeTokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"uid","type":"bytes32"}],"name":"getAndValidateBadge","outputs":[{"components":[{"internalType":"bytes32","name":"uid","type":"bytes32"},{"internalType":"bytes32","name":"schema","type":"bytes32"},{"internalType":"uint64","name":"time","type":"uint64"},{"internalType":"uint64","name":"expirationTime","type":"uint64"},{"internalType":"uint64","name":"revocationTime","type":"uint64"},{"internalType":"bytes32","name":"refUID","type":"bytes32"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"address","name":"attester","type":"address"},{"internalType":"bool","name":"revocable","type":"bool"},{"internalType":"bytes","name":"data","type":"bytes"}],"internalType":"struct Attestation","name":"","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"hasBadge","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"}],"name":"isEligible","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"bytes32","name":"uid","type":"bytes32"},{"internalType":"bytes32","name":"schema","type":"bytes32"},{"internalType":"uint64","name":"time","type":"uint64"},{"internalType":"uint64","name":"expirationTime","type":"uint64"},{"internalType":"uint64","name":"revocationTime","type":"uint64"},{"internalType":"bytes32","name":"refUID","type":"bytes32"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"address","name":"attester","type":"address"},{"internalType":"bool","name":"revocable","type":"bool"},{"internalType":"bytes","name":"data","type":"bytes"}],"internalType":"struct Attestation","name":"attestation","type":"tuple"}],"name":"issueBadge","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"resolver","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"bytes32","name":"uid","type":"bytes32"},{"internalType":"bytes32","name":"schema","type":"bytes32"},{"internalType":"uint64","name":"time","type":"uint64"},{"internalType":"uint64","name":"expirationTime","type":"uint64"},{"internalType":"uint64","name":"revocationTime","type":"uint64"},{"internalType":"bytes32","name":"refUID","type":"bytes32"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"address","name":"attester","type":"address"},{"internalType":"bool","name":"revocable","type":"bool"},{"internalType":"bytes","name":"data","type":"bytes"}],"internalType":"struct Attestation","name":"attestation","type":"tuple"}],"name":"revokeBadge","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
60a06040523480156200001157600080fd5b5060405162000ff538038062000ff58339810160408190526200003491620000a4565b6001600160a01b03838116608052600180546001600160a01b03191691841691909117905560026200006782826200022d565b50505050620002f9565b80516001600160a01b03811681146200008957600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b600080600060608486031215620000ba57600080fd5b620000c58462000071565b92506020620000d681860162000071565b60408601519093506001600160401b0380821115620000f457600080fd5b818701915087601f8301126200010957600080fd5b8151818111156200011e576200011e6200008e565b604051601f8201601f19908116603f011681019083821181831017156200014957620001496200008e565b816040528281528a868487010111156200016257600080fd5b600093505b8284101562000186578484018601518185018701529285019262000167565b60008684830101528096505050505050509250925092565b600181811c90821680620001b357607f821691505b602082108103620001d457634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200022857600081815260208120601f850160051c81016020861015620002035750805b601f850160051c820191505b8181101562000224578281556001016200020f565b5050505b505050565b81516001600160401b038111156200024957620002496200008e565b62000261816200025a84546200019e565b84620001da565b602080601f831160018114620002995760008415620002805750858301515b600019600386901b1c1916600185901b17855562000224565b600085815260208120601f198616915b82811015620002ca57888601518255948401946001909101908401620002a9565b5085821015620002e95787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b608051610ccc6200032960003960008181609d01528181610372015281816104b001526105780152610ccc6000f3fe608060405234801561001057600080fd5b50600436106100935760003560e01c80635e50864f116100665780635e50864f1461011757806366e305fd146101525780638298b030146101655780638c6f12f014610178578063d753a63d1461019857600080fd5b806304f3bcec1461009857806324830563146100dc5780633c130d90146100fc57806341decdd014610104575b600080fd5b6100bf7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020015b60405180910390f35b6100ef6100ea3660046107f4565b6101ab565b6040516100d3919061085d565b6100ef61023f565b6001546100bf906001600160a01b031681565b61014261012536600461088f565b6001600160a01b0316600090815260208190526040902054151590565b60405190151581526020016100d3565b61014261016036600461088f565b6102cd565b6101426101733660046108ac565b610365565b61018b6101863660046107f4565b610441565b6040516100d391906108e8565b6101426101a63660046108ac565b61056b565b6060600280546101ba906109bf565b80601f01602080910402602001604051908101604052809291908181526020018280546101e6906109bf565b80156102335780601f1061020857610100808354040283529160200191610233565b820191906000526020600020905b81548152906001019060200180831161021657829003601f168201915b50505050509050919050565b6002805461024c906109bf565b80601f0160208091040260200160405190810160405280929190818152602001828054610278906109bf565b80156102c55780601f1061029a576101008083540402835291602001916102c5565b820191906000526020600020905b8154815290600101906020018083116102a857829003601f168201915b505050505081565b6001600160a01b03811660009081526020819052604081205415801561035f57506001546040516370a0823160e01b81526001600160a01b03848116600483015260009216906370a0823190602401602060405180830381865afa158015610339573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061035d91906109f9565b115b92915050565b6000336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146103af576040516282b42960e81b815260040160405180910390fd5b6103b882610647565b6103c457506000919050565b60016000806103d960e0860160c0870161088f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060008282546104089190610a28565b90915550506040518235907f504e4727721de18c6bf7f66448a6ff6da00aa4b1f00b6034e71723ae7ce6373a90600090a2506001919050565b604080516101408101825260008082526020820181905281830181905260608083018290526080830182905260a0830182905260c0830182905260e08301829052610100830182905261012083015291516308c6f12f60e41b8152600481018490529091906001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690638c6f12f090602401600060405180830381865afa1580156104f7573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261051f9190810190610b3b565b90506000610531826101200151610666565b5090506001600160a01b03811630146105645760405163b923d26160e01b81526004810185905260240160405180910390fd5b5092915050565b6000336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146105b5576040516282b42960e81b815260040160405180910390fd5b6105be82610687565b6105ca57506000919050565b60016000806105df60e0860160c0870161088f565b6001600160a01b03166001600160a01b03168152602001908152602001600020600082825461060e9190610c32565b90915550506040518235907fa0785ec0b9bf31a5475d33c716fb9f500f0ea0bb9e4bc10ec39d5db763c1da1590600090a2506001919050565b600061065282610746565b61065e57506000919050565b506001919050565b600060608280602001905181019061067e9190610c45565b91509150915091565b600061069282610751565b61069e57506000919050565b6001546001600160a01b03166370a082316106bf60e0850160c0860161088f565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602401602060405180830381865afa158015610703573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072791906109f9565b60000361065e576040516282b42960e81b815260040160405180910390fd5b600061035f82610799565b600061075c826107a2565b61076857506000919050565b61077b61012560e0840160c0850161088f565b1561065e57604051630c59311960e11b815260040160405180910390fd5b6000600161035f565b60006107b5610100830160e0840161088f565b6001600160a01b03166107ce60e0840160c0850161088f565b6001600160a01b03161461065e576040516282b42960e81b815260040160405180910390fd5b60006020828403121561080657600080fd5b5035919050565b60005b83811015610828578181015183820152602001610810565b50506000910152565b6000815180845261084981602086016020860161080d565b601f01601f19169290920160200192915050565b6020815260006108706020830184610831565b9392505050565b6001600160a01b038116811461088c57600080fd5b50565b6000602082840312156108a157600080fd5b813561087081610877565b6000602082840312156108be57600080fd5b813567ffffffffffffffff8111156108d557600080fd5b8201610140818503121561087057600080fd5b6020815281516020820152602082015160408201526000604083015161091a606084018267ffffffffffffffff169052565b50606083015167ffffffffffffffff8116608084015250608083015167ffffffffffffffff811660a08401525060a083015160c083015260c083015161096b60e08401826001600160a01b03169052565b5060e0830151610100610988818501836001600160a01b03169052565b840151905061012061099d8482018315159052565b8401516101408481015290506109b7610160840182610831565b949350505050565b600181811c908216806109d357607f821691505b6020821081036109f357634e487b7160e01b600052602260045260246000fd5b50919050565b600060208284031215610a0b57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561035f5761035f610a12565b634e487b7160e01b600052604160045260246000fd5b604051610140810167ffffffffffffffff81118282101715610a7557610a75610a3b565b60405290565b805167ffffffffffffffff81168114610a9357600080fd5b919050565b8051610a9381610877565b80518015158114610a9357600080fd5b600082601f830112610ac457600080fd5b815167ffffffffffffffff80821115610adf57610adf610a3b565b604051601f8301601f19908116603f01168101908282118183101715610b0757610b07610a3b565b81604052838152866020858801011115610b2057600080fd5b610b3184602083016020890161080d565b9695505050505050565b600060208284031215610b4d57600080fd5b815167ffffffffffffffff80821115610b6557600080fd5b908301906101408286031215610b7a57600080fd5b610b82610a51565b8251815260208301516020820152610b9c60408401610a7b565b6040820152610bad60608401610a7b565b6060820152610bbe60808401610a7b565b608082015260a083015160a0820152610bd960c08401610a98565b60c0820152610bea60e08401610a98565b60e0820152610100610bfd818501610aa3565b908201526101208381015183811115610c1557600080fd5b610c2188828701610ab3565b918301919091525095945050505050565b8082018082111561035f5761035f610a12565b60008060408385031215610c5857600080fd5b8251610c6381610877565b602084015190925067ffffffffffffffff811115610c8057600080fd5b610c8c85828601610ab3565b915050925092905056fea264697066735822122011f8257df33a8a908b3f4fdc1f69e6d5a36edd420fca87c3168b1374c20c2b1c64736f6c634300081300330000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec0113000000000000000000000000b00910bac7da44c0d440798809dbf8d51fdbb6350000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000003668747470733a2f2f6173736574732e7a6e73636f6e6e6563742e696f2f7363726f6c6c2d62616467654d657461646174612e6a736f6e00000000000000000000
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106100935760003560e01c80635e50864f116100665780635e50864f1461011757806366e305fd146101525780638298b030146101655780638c6f12f014610178578063d753a63d1461019857600080fd5b806304f3bcec1461009857806324830563146100dc5780633c130d90146100fc57806341decdd014610104575b600080fd5b6100bf7f0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec011381565b6040516001600160a01b0390911681526020015b60405180910390f35b6100ef6100ea3660046107f4565b6101ab565b6040516100d3919061085d565b6100ef61023f565b6001546100bf906001600160a01b031681565b61014261012536600461088f565b6001600160a01b0316600090815260208190526040902054151590565b60405190151581526020016100d3565b61014261016036600461088f565b6102cd565b6101426101733660046108ac565b610365565b61018b6101863660046107f4565b610441565b6040516100d391906108e8565b6101426101a63660046108ac565b61056b565b6060600280546101ba906109bf565b80601f01602080910402602001604051908101604052809291908181526020018280546101e6906109bf565b80156102335780601f1061020857610100808354040283529160200191610233565b820191906000526020600020905b81548152906001019060200180831161021657829003601f168201915b50505050509050919050565b6002805461024c906109bf565b80601f0160208091040260200160405190810160405280929190818152602001828054610278906109bf565b80156102c55780601f1061029a576101008083540402835291602001916102c5565b820191906000526020600020905b8154815290600101906020018083116102a857829003601f168201915b505050505081565b6001600160a01b03811660009081526020819052604081205415801561035f57506001546040516370a0823160e01b81526001600160a01b03848116600483015260009216906370a0823190602401602060405180830381865afa158015610339573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061035d91906109f9565b115b92915050565b6000336001600160a01b037f0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec011316146103af576040516282b42960e81b815260040160405180910390fd5b6103b882610647565b6103c457506000919050565b60016000806103d960e0860160c0870161088f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060008282546104089190610a28565b90915550506040518235907f504e4727721de18c6bf7f66448a6ff6da00aa4b1f00b6034e71723ae7ce6373a90600090a2506001919050565b604080516101408101825260008082526020820181905281830181905260608083018290526080830182905260a0830182905260c0830182905260e08301829052610100830182905261012083015291516308c6f12f60e41b8152600481018490529091906001600160a01b037f0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec01131690638c6f12f090602401600060405180830381865afa1580156104f7573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261051f9190810190610b3b565b90506000610531826101200151610666565b5090506001600160a01b03811630146105645760405163b923d26160e01b81526004810185905260240160405180910390fd5b5092915050565b6000336001600160a01b037f0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec011316146105b5576040516282b42960e81b815260040160405180910390fd5b6105be82610687565b6105ca57506000919050565b60016000806105df60e0860160c0870161088f565b6001600160a01b03166001600160a01b03168152602001908152602001600020600082825461060e9190610c32565b90915550506040518235907fa0785ec0b9bf31a5475d33c716fb9f500f0ea0bb9e4bc10ec39d5db763c1da1590600090a2506001919050565b600061065282610746565b61065e57506000919050565b506001919050565b600060608280602001905181019061067e9190610c45565b91509150915091565b600061069282610751565b61069e57506000919050565b6001546001600160a01b03166370a082316106bf60e0850160c0860161088f565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602401602060405180830381865afa158015610703573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072791906109f9565b60000361065e576040516282b42960e81b815260040160405180910390fd5b600061035f82610799565b600061075c826107a2565b61076857506000919050565b61077b61012560e0840160c0850161088f565b1561065e57604051630c59311960e11b815260040160405180910390fd5b6000600161035f565b60006107b5610100830160e0840161088f565b6001600160a01b03166107ce60e0840160c0850161088f565b6001600160a01b03161461065e576040516282b42960e81b815260040160405180910390fd5b60006020828403121561080657600080fd5b5035919050565b60005b83811015610828578181015183820152602001610810565b50506000910152565b6000815180845261084981602086016020860161080d565b601f01601f19169290920160200192915050565b6020815260006108706020830184610831565b9392505050565b6001600160a01b038116811461088c57600080fd5b50565b6000602082840312156108a157600080fd5b813561087081610877565b6000602082840312156108be57600080fd5b813567ffffffffffffffff8111156108d557600080fd5b8201610140818503121561087057600080fd5b6020815281516020820152602082015160408201526000604083015161091a606084018267ffffffffffffffff169052565b50606083015167ffffffffffffffff8116608084015250608083015167ffffffffffffffff811660a08401525060a083015160c083015260c083015161096b60e08401826001600160a01b03169052565b5060e0830151610100610988818501836001600160a01b03169052565b840151905061012061099d8482018315159052565b8401516101408481015290506109b7610160840182610831565b949350505050565b600181811c908216806109d357607f821691505b6020821081036109f357634e487b7160e01b600052602260045260246000fd5b50919050565b600060208284031215610a0b57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561035f5761035f610a12565b634e487b7160e01b600052604160045260246000fd5b604051610140810167ffffffffffffffff81118282101715610a7557610a75610a3b565b60405290565b805167ffffffffffffffff81168114610a9357600080fd5b919050565b8051610a9381610877565b80518015158114610a9357600080fd5b600082601f830112610ac457600080fd5b815167ffffffffffffffff80821115610adf57610adf610a3b565b604051601f8301601f19908116603f01168101908282118183101715610b0757610b07610a3b565b81604052838152866020858801011115610b2057600080fd5b610b3184602083016020890161080d565b9695505050505050565b600060208284031215610b4d57600080fd5b815167ffffffffffffffff80821115610b6557600080fd5b908301906101408286031215610b7a57600080fd5b610b82610a51565b8251815260208301516020820152610b9c60408401610a7b565b6040820152610bad60608401610a7b565b6060820152610bbe60808401610a7b565b608082015260a083015160a0820152610bd960c08401610a98565b60c0820152610bea60e08401610a98565b60e0820152610100610bfd818501610aa3565b908201526101208381015183811115610c1557600080fd5b610c2188828701610ab3565b918301919091525095945050505050565b8082018082111561035f5761035f610a12565b60008060408385031215610c5857600080fd5b8251610c6381610877565b602084015190925067ffffffffffffffff811115610c8057600080fd5b610c8c85828601610ab3565b915050925092905056fea264697066735822122011f8257df33a8a908b3f4fdc1f69e6d5a36edd420fca87c3168b1374c20c2b1c64736f6c63430008130033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec0113000000000000000000000000b00910bac7da44c0d440798809dbf8d51fdbb6350000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000003668747470733a2f2f6173736574732e7a6e73636f6e6e6563742e696f2f7363726f6c6c2d62616467654d657461646174612e6a736f6e00000000000000000000
-----Decoded View---------------
Arg [0] : resolver_ (address): 0x4560FECd62B14A463bE44D40fE5Cfd595eEc0113
Arg [1] : _registry (address): 0xB00910Bac7DA44c0D440798809dbF8d51FDBb635
Arg [2] : _tokenURI (string): https://assets.znsconnect.io/scroll-badgeMetadata.json
-----Encoded View---------------
6 Constructor Arguments found :
Arg [0] : 0000000000000000000000004560fecd62b14a463be44d40fe5cfd595eec0113
Arg [1] : 000000000000000000000000b00910bac7da44c0d440798809dbf8d51fdbb635
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000060
Arg [3] : 0000000000000000000000000000000000000000000000000000000000000036
Arg [4] : 68747470733a2f2f6173736574732e7a6e73636f6e6e6563742e696f2f736372
Arg [5] : 6f6c6c2d62616467654d657461646174612e6a736f6e00000000000000000000
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 34 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
Loading...
Loading
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.