From 0ba24c2b518490f14f4a088cb8b70cf79becaf3e Mon Sep 17 00:00:00 2001 From: Andrew Richardson Date: Mon, 4 Mar 2024 08:41:58 -0500 Subject: [PATCH] Extend ERC1155URIStorage This makes the contracts more consistent with OpenZeppelin examples. No signatures are changed, but there is one slight change in behavior: if you specify a "base URI", then individual token URIs are always understood to be a suffix for that base URI. The previous contract would ignore the base URI when a token URI was specified. Signed-off-by: Andrew Richardson --- .../contracts/ERC1155MixedFungible.sol | 47 ++++++++----------- .../contracts/IERC1155MixedFungible.sol | 5 +- 2 files changed, 22 insertions(+), 30 deletions(-) diff --git a/samples/solidity/contracts/ERC1155MixedFungible.sol b/samples/solidity/contracts/ERC1155MixedFungible.sol index e526c1e..6d43535 100644 --- a/samples/solidity/contracts/ERC1155MixedFungible.sol +++ b/samples/solidity/contracts/ERC1155MixedFungible.sol @@ -1,7 +1,7 @@ // SPDX-License-Identifier: Apache-2.0 pragma solidity ^0.8.0; -import '@openzeppelin/contracts/token/ERC1155/ERC1155.sol'; +import '@openzeppelin/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol'; import '@openzeppelin/contracts/utils/Context.sol'; import './IERC1155MixedFungible.sol'; @@ -27,7 +27,7 @@ import './IERC1155MixedFungible.sol'; * Remember to always consult best practices from other communities and examples (such as OpenZeppelin) * when crafting your token logic, rather than relying on the FireFly community alone. Happy minting! */ -contract ERC1155MixedFungible is Context, ERC1155, IERC1155MixedFungible { +contract ERC1155MixedFungible is Context, ERC1155URIStorage, IERC1155MixedFungible { // Use a split bit implementation: // - Bit 255: type flag (0 = fungible, 1 = non-fungible) // - Bits 255-128: type id @@ -44,10 +44,6 @@ contract ERC1155MixedFungible is Context, ERC1155, IERC1155MixedFungible { // inherited ERC1155 `_uri` is private, so need our own within this contract string private _baseTokenURI; - // mapping from type ID | index => custom token URIs for non-fungible tokens - // fallback behavior if missing is to use the default base URI - mapping(uint256 => string) private _nfTokenURIs; - function isFungible(uint256 id) internal pure returns (bool) { return id & TYPE_NF_BIT == 0; } @@ -89,18 +85,6 @@ contract ERC1155MixedFungible is Context, ERC1155, IERC1155MixedFungible { ); } - function _setNonFungibleURI( - uint256 type_id, - uint256 id, - string memory _uri - ) private creatorOnly(type_id) { - require( - isNonFungible(type_id), - 'ERC1155MixedFungible: id does not represent a non-fungible type' - ); - _nfTokenURIs[id] = _uri; - } - function mintNonFungible( uint256 type_id, address[] calldata to, @@ -138,7 +122,7 @@ contract ERC1155MixedFungible is Context, ERC1155, IERC1155MixedFungible { for (uint256 i = 0; i < to.length; ++i) { uint256 id = type_id | (index + i); _mint(to[i], id, 1, data); - _setNonFungibleURI(type_id, id, _uri); + _setURI(id, _uri); } } @@ -185,15 +169,22 @@ contract ERC1155MixedFungible is Context, ERC1155, IERC1155MixedFungible { function uri( uint256 id - ) public view virtual override(IERC1155MixedFungible, ERC1155) returns (string memory) { - string memory _tokenUri = _nfTokenURIs[id]; - bytes memory tempURITest = bytes(_tokenUri); - - if (tempURITest.length == 0) { - return _baseTokenURI; - } else { - return _tokenUri; - } + ) + public + view + virtual + override(IERC1155MixedFungible, ERC1155URIStorage) + returns (string memory) + { + return super.uri(id); + } + + function _setURI(uint256 id, string memory tokenURI) internal virtual override { + require( + isNonFungible(id), + 'ERC1155MixedFungible: id does not represent a non-fungible type' + ); + super._setURI(id, tokenURI); } function baseTokenUri() public view virtual override returns (string memory) { diff --git a/samples/solidity/contracts/IERC1155MixedFungible.sol b/samples/solidity/contracts/IERC1155MixedFungible.sol index 79c4360..fb80520 100644 --- a/samples/solidity/contracts/IERC1155MixedFungible.sol +++ b/samples/solidity/contracts/IERC1155MixedFungible.sol @@ -2,6 +2,7 @@ pragma solidity ^0.8.0; +import '@openzeppelin/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol'; import '@openzeppelin/contracts/utils/introspection/IERC165.sol'; import './IERC1155Factory.sol'; @@ -9,7 +10,7 @@ import './IERC1155Factory.sol'; * ERC1155 interface with mint, burn, and attached data support for fungible & non-fungible tokens. * Non-fungible tokens also have support for custom URI's. */ -interface IERC1155MixedFungible is IERC165, IERC1155Factory { +interface IERC1155MixedFungible is IERC165, IERC1155Factory, IERC1155MetadataURI { function create(bool is_fungible, bytes calldata data) external override; function mintNonFungible(uint256 type_id, address[] calldata to, bytes calldata data) external; @@ -36,7 +37,7 @@ interface IERC1155MixedFungible is IERC165, IERC1155Factory { bytes calldata data ) external; - function uri(uint256 id) external returns (string memory); + function uri(uint256 id) external view returns (string memory); function baseTokenUri() external returns (string memory); }