aboutsummaryrefslogtreecommitdiffstats
path: root/packages/contracts/src/2.0.0/test/DummyERC721Token/DummyERC721Token.sol
blob: 627746a522085114a1f2897699d6fd973b8a2ba1 (plain) (blame)
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
76
/*

  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;

import "../../tokens/ERC721Token/ERC721Token.sol";
import "../../utils/Ownable/Ownable.sol";


// solhint-disable no-empty-blocks
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);
    }
}