Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion app/models/erc721_ethscriptions_collection_parser.rb
Original file line number Diff line number Diff line change
Expand Up @@ -508,7 +508,7 @@ def validate_bytes32(value, field_name)
end

def validate_address(value, field_name)
unless value.is_a?(String) && value.match?(/\A0x[0-9a-f]{40}\z/)
unless value.is_a?(String) && value.match?(/\A0x[0-9a-f]{40}\z/i)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Bug: Inconsistent Case Sensitivity Bypasses Validation

The validate_address method now accepts case-insensitive addresses via the /i regex flag, but the zero address check on line 515 uses a case-sensitive string comparison. This allows uppercase or mixed-case variants of the zero address (like 0x0000000000000000000000000000000000000000 with capital letters) to bypass the zero address validation, even though they represent the same address. The check needs to compare the downcased value or normalize before comparing.

Fix in Cursor Fix in Web

raise ValidationError, "Invalid address for #{field_name}: #{value}"
end

Expand Down
10 changes: 5 additions & 5 deletions contracts/src/NameRegistry.sol
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ contract NameRegistry is ERC721EthscriptionsEnumerableUpgradeable, IProtocolHand
bytes memory json = abi.encodePacked(
'{"name":"',
name.escapeJSON(),
'","description":"Dotless word domain"',
'","description":"An Ethscriptions name"',
',"ethscription_id":"',
ethscriptionIdHex,
'","ethscription_number":',
Expand All @@ -207,9 +207,9 @@ contract NameRegistry is ERC721EthscriptionsEnumerableUpgradeable, IProtocolHand
'":"',
mediaUri,
'","attributes":[',
'{"trait_type":"Name","value":"',
name.escapeJSON(),
'"}',
'{"trait_type":"Length","value":',
bytes(name).length.toString(),
',"display_type":"number"}',
']}'
);

Expand All @@ -223,7 +223,7 @@ contract NameRegistry is ERC721EthscriptionsEnumerableUpgradeable, IProtocolHand
'data:application/json;base64,',
Base64.encode(bytes(
'{"name":"Word Domains Registry",'
'"description":"On-chain word domain name system for Ethscriptions. Register unique, dotless domain names as NFTs.",'
'"description":"On-chain name system for Ethscriptions. Allowed characters: a-z, 0-9, and _ (underscore). Max length: 30 characters.",'
'"image":"",'
'"external_link":"https://ethscriptions.com"}'
))
Expand Down
Loading