1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
/*
Copyright 2018 ZeroEx Intl.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
pragma solidity ^0.4.24;
pragma experimental ABIEncoderV2;
import "../../tokens/ERC721Token/ERC721Token.sol";
import "../../utils/Ownable/Ownable.sol";
contract DummyERC721Token is
Ownable,
ERC721Token
{
/**
* @dev Constructor passes its arguments to the base ERC721Token constructor
* @param name of token
* @param symbol of token
*/
constructor (
string name,
string symbol
)
public
ERC721Token(name, symbol)
{}
/**
* @dev Function to mint a new token
* @dev Reverts if the given token ID already exists
* @param to address the beneficiary that will own the minted token
* @param tokenId uint256 ID of the token to be minted by the msg.sender
*/
function mint(address to, uint256 tokenId)
public
onlyOwner
{
require(
!exists(tokenId),
"Token with tokenId already exists."
);
_mint(to, tokenId);
}
/**
* @dev Function to burn a token
* @dev Reverts if the given token ID doesn't exist
* @param tokenId uint256 ID of the token to be minted by the msg.sender
*/
function burn(address owner, uint256 tokenId)
public
onlyOwner
{
require(
exists(tokenId),
"Token with tokenId does not exist."
);
_burn(owner, tokenId);
}
}
|