Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add ERC721 Wrapper #3863

Merged
merged 38 commits into from
Feb 9, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
36f15d1
Feature: ERC721 Wrapper
ernestognw Dec 7, 2022
50cceb1
Add PR link
ernestognw Dec 7, 2022
e0c02e6
Added tests
ernestognw Dec 10, 2022
42a681a
Update version
ernestognw Dec 12, 2022
73e498b
Add batching
ernestognw Dec 16, 2022
83f3a0a
Update wording
ernestognw Dec 19, 2022
b76c741
Check ownership or approval in `withdrawTo`
ernestognw Jan 4, 2023
8d8788d
Support minting on `onERC721Received` check
ernestognw Jan 4, 2023
4fdb735
Merge branch 'master' into feature/erc721-wrapper
ernestognw Jan 4, 2023
89d13d8
Fix `onERC721Received` param location and ran prettier
ernestognw Jan 4, 2023
bf1dbb7
Applied prettier to tests
ernestognw Jan 4, 2023
4348d23
Switched to hardhat-exposed features
ernestognw Jan 4, 2023
59a7491
Remove ERC721WrapperMock
ernestognw Jan 4, 2023
cd5c4b9
Cache sloads
Amxx Jan 4, 2023
265d596
Fix lint
ernestognw Jan 9, 2023
aa7f791
Update ERC721.behavior.js
Amxx Jan 10, 2023
7c35759
add test: onERC721Received to another account
Amxx Jan 10, 2023
75074df
Add extra comment
ernestognw Jan 24, 2023
3d0438c
Merge branch 'master' into feature/erc721-wrapper
ernestognw Jan 24, 2023
77fcda8
Merge branch 'master' into feature/erc721-wrapper
ernestognw Jan 24, 2023
3cc752c
Add changeset
ernestognw Jan 24, 2023
24ac3dc
Accept suggestion
ernestognw Jan 24, 2023
935e84b
Fix: Add reentrancy note
ernestognw Jan 24, 2023
f9ee65e
Remove warning
ernestognw Jan 24, 2023
0adf63e
Update docs/modules/ROOT/pages/governance.adoc
ernestognw Jan 24, 2023
16daba8
Remove unnecesary file
ernestognw Feb 3, 2023
1695aaa
Move `underlying` to private and complete branch coverage tests
ernestognw Feb 3, 2023
fb22e8d
Add magic value
ernestognw Feb 3, 2023
3f5b0f3
Switch to bytes12 for magic value
ernestognw Feb 3, 2023
17a5475
Lint
ernestognw Feb 3, 2023
24b1033
Change magic value check
ernestognw Feb 3, 2023
1fd1094
Merge branch 'master' into feature/erc721-wrapper
ernestognw Feb 4, 2023
ca26854
Make magic value public
ernestognw Feb 7, 2023
29f31f7
Missing change
ernestognw Feb 7, 2023
d51374b
Merge branch 'master' into feature/erc721-wrapper
ernestognw Feb 7, 2023
92d650b
Merge branch 'master' into feature/erc721-wrapper
Amxx Feb 8, 2023
b49c187
Make `onERC721Received` more strict with the magic value
ernestognw Feb 8, 2023
e6eb16d
Merge branch 'master' into feature/erc721-wrapper
ernestognw Feb 8, 2023
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
Prev Previous commit
Next Next commit
Move underlying to private and complete branch coverage tests
  • Loading branch information
ernestognw committed Feb 3, 2023
commit 1695aaa680de2b4aa8c2fcbb4d415498d2a6ac9d
19 changes: 13 additions & 6 deletions contracts/token/ERC721/extensions/ERC721Wrapper.sol
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@ import "../utils/ERC721Holder.sol";
* _Available since v4.9.0_
*/
abstract contract ERC721Wrapper is ERC721, ERC721Holder {
IERC721 public immutable underlying;
IERC721 private immutable _underlying;

constructor(IERC721 underlyingToken) {
underlying = underlyingToken;
_underlying = underlyingToken;
}

/**
Expand All @@ -29,7 +29,7 @@ abstract contract ERC721Wrapper is ERC721, ERC721Holder {

uint256 length = tokenIds.length;
for (uint256 i = 0; i < length; ++i) {
underlying.safeTransferFrom(_msgSender(), address(this), tokenIds[i], data);
underlying().safeTransferFrom(_msgSender(), address(this), tokenIds[i], data);
}

return true;
Expand All @@ -47,7 +47,7 @@ abstract contract ERC721Wrapper is ERC721, ERC721Holder {
// Checks were already performed at this point, and there's no way to retake ownership or approval from
// the wrapped tokenId after this point, so it's safe to remove the reentrancy check for the next line.
// slither-disable-next-line reentrancy-no-eth
underlying.safeTransferFrom(address(this), account, tokenId);
underlying().safeTransferFrom(address(this), account, tokenId);
}

return true;
Expand All @@ -66,7 +66,7 @@ abstract contract ERC721Wrapper is ERC721, ERC721Holder {
uint256 tokenId,
bytes memory data
) public override returns (bytes4) {
require(msg.sender == address(underlying));
require(msg.sender == address(underlying()), "ERC721Wrapper: caller is not underlying");
_safeMint(data.length == 0 ? from : abi.decode(data, (address)), tokenId);
frangio marked this conversation as resolved.
Show resolved Hide resolved
return IERC721Receiver.onERC721Received.selector;
}
Expand All @@ -76,8 +76,15 @@ abstract contract ERC721Wrapper is ERC721, ERC721Holder {
* function that can be exposed with access control if desired.
*/
function _recover(address account, uint256 tokenId) internal virtual returns (uint256) {
require(underlying.ownerOf(tokenId) == address(this), "ERC721Wrapper: wrapper is not token owner");
require(underlying().ownerOf(tokenId) == address(this), "ERC721Wrapper: wrapper is not token owner");
_safeMint(account, tokenId);
return tokenId;
}

/**
* @dev Returns the underlying token.
*/
function underlying() public view virtual returns (IERC721) {
return _underlying;
}
}
13 changes: 13 additions & 0 deletions test/token/ERC721/extensions/ERC721Wrapper.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,19 @@ contract('ERC721Wrapper', function (accounts) {
tokenId: firstTokenId,
});
});

it('only allows calls from underlying', async function () {
await expectRevert(
this.token.onERC721Received(
initialHolder,
this.token.address,
firstTokenId,
web3.eth.abi.encodeParameters(['address'], [anotherAccount]),
{ from: anotherAccount },
),
'ERC721Wrapper: caller is not underlying',
);
});
});

describe('_recover', function () {
Expand Down