* Initial migration to Solidity 0.6.x - v3.0 first steps (#2063) * Initial migration, missing GSN, 721, 777 and Crowdsales. * Add _beforeTokenOperation and _afterTokenOperation. * Add documentation for hooks. * Add hooks doc * Add missing drafts * Add back ERC721 with hooks * Bring back ERC777 * Notes on hooks * Bring back GSN * Make functions virtual * Make GSN overrides explicit * Fix ERC20Pausable tests * Remove virtual from some view functions * Update linter * Delete examples * Remove unnecessary virtual * Remove roles from Pausable * Remove roles * Remove users of roles * Adapt ERC20 tests * Fix ERC721 tests * Add all ERC721 hooks * Add ERC777 hooks * Fix remaining tests * Bump compiler version * Move 721BurnableMock into mocks directory * Remove _before hooks * Fix tests * Upgrade linter * Put modifiers last * Remove _beforeTokenApproval and _beforeOperatorApproval hooks
38 lines
1.2 KiB
Solidity
38 lines
1.2 KiB
Solidity
pragma solidity ^0.6.0;
|
|
|
|
import "../token/ERC721/ERC721Full.sol";
|
|
import "../token/ERC721/ERC721Burnable.sol";
|
|
|
|
/**
|
|
* @title ERC721FullMock
|
|
* This mock just provides public functions for setting metadata URI, getting all tokens of an owner,
|
|
* checking token existence, removal of a token from an address
|
|
*/
|
|
contract ERC721FullMock is ERC721Full, ERC721Burnable {
|
|
constructor (string memory name, string memory symbol) public ERC721Full(name, symbol) { }
|
|
|
|
function exists(uint256 tokenId) public view returns (bool) {
|
|
return _exists(tokenId);
|
|
}
|
|
|
|
function tokensOfOwner(address owner) public view returns (uint256[] memory) {
|
|
return _tokensOfOwner(owner);
|
|
}
|
|
|
|
function setTokenURI(uint256 tokenId, string memory uri) public {
|
|
_setTokenURI(tokenId, uri);
|
|
}
|
|
|
|
function setBaseURI(string memory baseURI) public {
|
|
_setBaseURI(baseURI);
|
|
}
|
|
|
|
function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal virtual override(ERC721, ERC721Full) {
|
|
super._beforeTokenTransfer(from, to, tokenId);
|
|
}
|
|
|
|
function mint(address to, uint256 tokenId) public {
|
|
_mint(to, tokenId);
|
|
}
|
|
}
|