@etherisc/gif-next 0.0.2-9b97b55 → 0.0.2-a0d749a
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +2 -2
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +2 -2
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +2 -2
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2 -2
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +2 -2
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +2 -2
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +2 -2
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +453 -0
- package/contracts/components/Component.sol +16 -18
- package/contracts/components/IPool.sol +3 -3
- package/contracts/components/IProduct.sol +3 -6
- package/contracts/components/Pool.sol +6 -13
- package/contracts/components/Product.sol +10 -21
- package/contracts/experiment/errors/Require.sol +10 -5
- package/contracts/experiment/errors/Revert.sol +13 -8
- package/contracts/experiment/inheritance/A.sol +8 -11
- package/contracts/experiment/inheritance/B.sol +10 -5
- package/contracts/experiment/inheritance/C.sol +11 -5
- package/contracts/experiment/inheritance/IA.sol +2 -7
- package/contracts/experiment/inheritance/IB.sol +3 -2
- package/contracts/experiment/inheritance/IC.sol +4 -3
- package/contracts/experiment/types/TypeA.sol +14 -9
- package/contracts/experiment/types/TypeB.sol +14 -9
- package/contracts/instance/IInstance.sol +1 -3
- package/contracts/instance/Instance.sol +13 -13
- package/contracts/instance/access/Access.sol +63 -116
- package/contracts/instance/access/IAccess.sol +28 -48
- package/contracts/instance/component/ComponentModule.sol +63 -98
- package/contracts/instance/component/IComponent.sol +30 -52
- package/contracts/instance/policy/IPolicy.sol +9 -24
- package/contracts/instance/policy/PolicyModule.sol +19 -35
- package/contracts/instance/pool/IPoolModule.sol +7 -19
- package/contracts/instance/pool/PoolModule.sol +22 -35
- package/contracts/instance/product/IProductService.sol +5 -15
- package/contracts/instance/product/ProductService.sol +43 -39
- package/contracts/registry/ChainNft.sol +23 -61
- package/contracts/registry/IChainNft.sol +10 -7
- package/contracts/registry/IRegistry.sol +46 -36
- package/contracts/registry/Registry.sol +80 -53
- package/contracts/types/Blocknumber.sol +76 -18
- package/contracts/types/ChainId.sol +18 -10
- package/contracts/types/NftId.sol +29 -13
- package/contracts/types/Timestamp.sol +63 -16
- package/contracts/types/UFixed.sol +205 -0
- package/package.json +9 -4
@@ -4,10 +4,7 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {ERC721, ERC721Enumerable} from "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
|
5
5
|
import {IChainNft} from "./IChainNft.sol";
|
6
6
|
|
7
|
-
contract ChainNft is
|
8
|
-
ERC721Enumerable,
|
9
|
-
IChainNft
|
10
|
-
{
|
7
|
+
contract ChainNft is ERC721Enumerable, IChainNft {
|
11
8
|
string public constant NAME = "Dezentralized Insurance Protocol Registry";
|
12
9
|
string public constant SYMBOL = "DIPR";
|
13
10
|
|
@@ -18,22 +15,18 @@ contract ChainNft is
|
|
18
15
|
address private _registry;
|
19
16
|
|
20
17
|
// only used for _getNextTokenId
|
21
|
-
uint256 internal _chainIdInt;
|
18
|
+
uint256 internal _chainIdInt;
|
22
19
|
uint256 internal _chainIdDigits;
|
23
20
|
uint256 internal _chainIdMultiplier;
|
24
21
|
uint256 internal _idNext;
|
25
22
|
uint256 internal _totalMinted;
|
26
23
|
|
27
|
-
|
28
24
|
modifier onlyRegistry() {
|
29
25
|
require(msg.sender == _registry, "ERROR:NFT-001:CALLER_NOT_REGISTRY");
|
30
26
|
_;
|
31
27
|
}
|
32
28
|
|
33
|
-
|
34
|
-
constructor(address registry)
|
35
|
-
ERC721(NAME, SYMBOL)
|
36
|
-
{
|
29
|
+
constructor(address registry) ERC721(NAME, SYMBOL) {
|
37
30
|
require(registry != address(0), "ERROR:NFT-010:REGISTRY_ZERO");
|
38
31
|
|
39
32
|
_registry = registry;
|
@@ -43,88 +36,59 @@ contract ChainNft is
|
|
43
36
|
_chainIdMultiplier = 10 ** _chainIdDigits;
|
44
37
|
|
45
38
|
// on mainnet/goerli start /1 (reserved for protocol nft) on other chains with 2
|
46
|
-
if(block.chainid == 1 || block.chainid == 5) {
|
39
|
+
if (block.chainid == 1 || block.chainid == 5) {
|
47
40
|
_idNext = 1;
|
48
41
|
} else {
|
49
42
|
_idNext = 2;
|
50
43
|
}
|
51
44
|
}
|
52
45
|
|
53
|
-
|
54
46
|
function mint(
|
55
47
|
address to,
|
56
48
|
string memory uri
|
57
|
-
)
|
58
|
-
external
|
59
|
-
override
|
60
|
-
onlyRegistry
|
61
|
-
returns(uint256 tokenId)
|
62
|
-
{
|
49
|
+
) external override onlyRegistry returns (uint256 tokenId) {
|
63
50
|
tokenId = _getNextTokenId();
|
64
51
|
_totalMinted++;
|
65
52
|
|
66
53
|
_safeMint(to, tokenId);
|
67
54
|
|
68
|
-
if(bytes(uri).length > 0) {
|
55
|
+
if (bytes(uri).length > 0) {
|
69
56
|
_uri[tokenId] = uri;
|
70
57
|
}
|
71
58
|
}
|
72
59
|
|
73
|
-
|
74
|
-
function burn(uint256 tokenId)
|
75
|
-
external
|
76
|
-
override
|
77
|
-
onlyRegistry
|
78
|
-
{
|
60
|
+
function burn(uint256 tokenId) external override onlyRegistry {
|
79
61
|
_requireMinted(tokenId);
|
80
62
|
_burn(tokenId);
|
81
63
|
delete _uri[tokenId];
|
82
64
|
}
|
83
65
|
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
onlyRegistry
|
89
|
-
{
|
66
|
+
function setURI(
|
67
|
+
uint256 tokenId,
|
68
|
+
string memory uri
|
69
|
+
) external override onlyRegistry {
|
90
70
|
require(bytes(uri).length > 0, "ERROR:CRG-011:URI_EMPTY");
|
91
71
|
|
92
72
|
_requireMinted(tokenId);
|
93
73
|
_uri[tokenId] = uri;
|
94
74
|
}
|
95
75
|
|
96
|
-
|
97
|
-
function exists(uint256 tokenId)
|
98
|
-
external
|
99
|
-
view
|
100
|
-
override
|
101
|
-
returns(bool)
|
102
|
-
{
|
76
|
+
function exists(uint256 tokenId) external view override returns (bool) {
|
103
77
|
return _exists(tokenId);
|
104
78
|
}
|
105
79
|
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
view
|
110
|
-
override
|
111
|
-
returns(string memory)
|
112
|
-
{
|
80
|
+
function tokenURI(
|
81
|
+
uint256 tokenId
|
82
|
+
) public view override returns (string memory) {
|
113
83
|
_requireMinted(tokenId);
|
114
84
|
return _uri[tokenId];
|
115
85
|
}
|
116
86
|
|
117
|
-
|
118
|
-
function getRegistryAddress()
|
119
|
-
external
|
120
|
-
view
|
121
|
-
override
|
122
|
-
returns(address)
|
123
|
-
{
|
87
|
+
function getRegistryAddress() external view override returns (address) {
|
124
88
|
return _registry;
|
125
89
|
}
|
126
90
|
|
127
|
-
function totalMinted() external override
|
91
|
+
function totalMinted() external view override returns (uint256) {
|
128
92
|
return _totalMinted;
|
129
93
|
}
|
130
94
|
|
@@ -153,17 +117,15 @@ contract ChainNft is
|
|
153
117
|
// (42 * 10 ** 10 + 9876543210) * 100 + 10
|
154
118
|
// (index * 10 ** digits + chainid) * 100 + digits (1 < digits < 100)
|
155
119
|
|
156
|
-
function _getNextTokenId() private returns(uint256 id) {
|
157
|
-
id =
|
120
|
+
function _getNextTokenId() private returns (uint256 id) {
|
121
|
+
id =
|
122
|
+
(_idNext * _chainIdMultiplier + _chainIdInt) *
|
123
|
+
100 +
|
124
|
+
_chainIdDigits;
|
158
125
|
_idNext++;
|
159
126
|
}
|
160
127
|
|
161
|
-
|
162
|
-
function _countDigits(uint256 num)
|
163
|
-
private
|
164
|
-
pure
|
165
|
-
returns (uint256 count)
|
166
|
-
{
|
128
|
+
function _countDigits(uint256 num) private pure returns (uint256 count) {
|
167
129
|
count = 0;
|
168
130
|
while (num != 0) {
|
169
131
|
count++;
|
@@ -3,16 +3,19 @@ pragma solidity ^0.8.19;
|
|
3
3
|
|
4
4
|
import {IERC721Enumerable} from "@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol";
|
5
5
|
|
6
|
-
interface IChainNft is
|
7
|
-
|
8
|
-
|
6
|
+
interface IChainNft is IERC721Enumerable {
|
7
|
+
function mint(
|
8
|
+
address to,
|
9
|
+
string memory uri
|
10
|
+
) external returns (uint256 tokenId);
|
9
11
|
|
10
|
-
function mint(address to, string memory uri) external returns(uint256 tokenId);
|
11
12
|
function burn(uint256 tokenId) external;
|
13
|
+
|
12
14
|
function setURI(uint256 tokenId, string memory uri) external;
|
13
15
|
|
14
|
-
function exists(uint256 tokenId) external view returns(bool);
|
15
|
-
|
16
|
+
function exists(uint256 tokenId) external view returns (bool);
|
17
|
+
|
18
|
+
function totalMinted() external view returns (uint256);
|
16
19
|
|
17
|
-
function getRegistryAddress() external view returns(address registry);
|
20
|
+
function getRegistryAddress() external view returns (address registry);
|
18
21
|
}
|
@@ -4,36 +4,34 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {NftId} from "../types/NftId.sol";
|
5
5
|
|
6
6
|
interface IOwnable {
|
7
|
-
function getOwner() external view returns(address owner);
|
7
|
+
function getOwner() external view returns (address owner);
|
8
8
|
}
|
9
9
|
|
10
10
|
interface IRegistryLinked {
|
11
|
-
|
12
11
|
event LogDebug(uint256 idx, address module, string comment);
|
13
12
|
|
14
|
-
function getRegistry() external view returns(IRegistry registry);
|
13
|
+
function getRegistry() external view returns (IRegistry registry);
|
15
14
|
}
|
16
15
|
|
17
|
-
interface IRegisterable is
|
18
|
-
|
19
|
-
IRegistryLinked
|
20
|
-
{
|
21
|
-
|
22
|
-
function register() external returns(NftId nftId);
|
23
|
-
|
24
|
-
function getNftId() external view returns(NftId nftId);
|
25
|
-
function getParentNftId() external view returns(NftId parentNftId);
|
26
|
-
function getType() external view returns(uint256 objectType);
|
27
|
-
function getData() external view returns(bytes memory data);
|
28
|
-
function isRegisterable() external pure returns(bool);
|
29
|
-
function getInitialOwner() external view returns(address initialOwner);
|
30
|
-
|
31
|
-
function isRegistered() external view returns(bool);
|
32
|
-
}
|
16
|
+
interface IRegisterable is IOwnable, IRegistryLinked {
|
17
|
+
function register() external returns (NftId nftId);
|
33
18
|
|
19
|
+
function getNftId() external view returns (NftId nftId);
|
34
20
|
|
35
|
-
|
21
|
+
function getParentNftId() external view returns (NftId parentNftId);
|
22
|
+
|
23
|
+
function getType() external view returns (uint256 objectType);
|
24
|
+
|
25
|
+
function getData() external view returns (bytes memory data);
|
36
26
|
|
27
|
+
function isRegisterable() external pure returns (bool);
|
28
|
+
|
29
|
+
function getInitialOwner() external view returns (address initialOwner);
|
30
|
+
|
31
|
+
function isRegistered() external view returns (bool);
|
32
|
+
}
|
33
|
+
|
34
|
+
interface IRegistry {
|
37
35
|
struct RegistryInfo {
|
38
36
|
NftId nftId;
|
39
37
|
NftId parentNftId;
|
@@ -42,29 +40,41 @@ interface IRegistry {
|
|
42
40
|
address initialOwner;
|
43
41
|
}
|
44
42
|
|
45
|
-
function TOKEN() external pure returns(uint256);
|
46
|
-
|
47
|
-
function
|
48
|
-
|
49
|
-
function
|
50
|
-
|
51
|
-
function
|
43
|
+
function TOKEN() external pure returns (uint256);
|
44
|
+
|
45
|
+
function INSTANCE() external pure returns (uint256);
|
46
|
+
|
47
|
+
function PRODUCT() external pure returns (uint256);
|
48
|
+
|
49
|
+
function ORACLE() external pure returns (uint256);
|
50
|
+
|
51
|
+
function POOL() external pure returns (uint256);
|
52
|
+
|
53
|
+
function POLICY() external pure returns (uint256);
|
54
|
+
|
55
|
+
function BUNDLE() external pure returns (uint256);
|
56
|
+
|
57
|
+
function register(address objectAddress) external returns (NftId nftId);
|
52
58
|
|
53
|
-
function register(address objectAddress) external returns(NftId nftId);
|
54
59
|
function registerObjectForInstance(
|
55
60
|
NftId parentNftid,
|
56
61
|
uint256 objectType,
|
57
62
|
address initialOwner
|
58
|
-
)
|
59
|
-
|
63
|
+
) external returns (NftId nftId);
|
64
|
+
|
65
|
+
function getObjectCount() external view returns (uint256);
|
66
|
+
|
67
|
+
function getNftId(
|
68
|
+
address objectAddress
|
69
|
+
) external view returns (NftId nftId);
|
60
70
|
|
61
|
-
function
|
71
|
+
function getInfo(
|
72
|
+
NftId nftId
|
73
|
+
) external view returns (RegistryInfo memory info);
|
62
74
|
|
63
|
-
function
|
64
|
-
function getInfo(NftId nftId) external view returns(RegistryInfo memory info);
|
65
|
-
function getOwner(NftId nftId) external view returns(address ownerAddress);
|
75
|
+
function getOwner(NftId nftId) external view returns (address ownerAddress);
|
66
76
|
|
67
|
-
function isRegistered(address objectAddress) external view returns(bool);
|
77
|
+
function isRegistered(address objectAddress) external view returns (bool);
|
68
78
|
|
69
|
-
function getNftAddress() external view returns(address nft);
|
79
|
+
function getNftAddress() external view returns (address nft);
|
70
80
|
}
|
@@ -7,59 +7,50 @@ import {NftId, toNftId} from "../types/NftId.sol";
|
|
7
7
|
import {NftIdLib} from "../types/NftId.sol";
|
8
8
|
|
9
9
|
contract RegistryLinked is IRegistryLinked {
|
10
|
-
|
11
10
|
IRegistry internal _registry;
|
12
|
-
|
11
|
+
|
13
12
|
constructor(address registry) {
|
14
13
|
_registry = IRegistry(registry);
|
15
14
|
}
|
16
15
|
|
17
|
-
function getRegistry() external view override returns(IRegistry registry) {
|
16
|
+
function getRegistry() external view override returns (IRegistry registry) {
|
18
17
|
return _registry;
|
19
18
|
}
|
20
|
-
|
21
19
|
}
|
22
20
|
|
23
|
-
|
24
|
-
abstract contract Registerable is
|
25
|
-
RegistryLinked,
|
26
|
-
IRegisterable
|
27
|
-
{
|
21
|
+
abstract contract Registerable is RegistryLinked, IRegisterable {
|
28
22
|
using NftIdLib for NftId;
|
29
23
|
|
30
24
|
address private _initialOwner;
|
31
|
-
|
32
|
-
constructor(address registry)
|
33
|
-
RegistryLinked(registry)
|
34
|
-
{
|
25
|
+
|
26
|
+
constructor(address registry) RegistryLinked(registry) {
|
35
27
|
_initialOwner = msg.sender;
|
36
28
|
}
|
37
29
|
|
38
30
|
// getType, getData and register need to be implemented by concrete contract
|
39
31
|
|
40
|
-
function isRegisterable() external pure override returns(bool) {
|
32
|
+
function isRegisterable() external pure override returns (bool) {
|
41
33
|
return true;
|
42
34
|
}
|
43
35
|
|
44
|
-
function getInitialOwner() public view override returns(address deployer) {
|
36
|
+
function getInitialOwner() public view override returns (address deployer) {
|
45
37
|
return _initialOwner;
|
46
38
|
}
|
47
39
|
|
48
|
-
function isRegistered() public view override returns(bool) {
|
40
|
+
function isRegistered() public view override returns (bool) {
|
49
41
|
NftId nftId = _registry.getNftId(address(this));
|
50
42
|
return nftId.gtz();
|
51
43
|
}
|
52
44
|
|
53
|
-
function getNftId() public view override returns(NftId nftId) {
|
45
|
+
function getNftId() public view override returns (NftId nftId) {
|
54
46
|
return _registry.getNftId(address(this));
|
55
47
|
}
|
56
48
|
|
57
|
-
function getOwner() public view override returns(address owner) {
|
49
|
+
function getOwner() public view override returns (address owner) {
|
58
50
|
NftId id = _registry.getNftId(address(this));
|
59
51
|
owner = _registry.getOwner(id);
|
60
52
|
return owner != address(0) ? owner : _initialOwner;
|
61
53
|
}
|
62
|
-
|
63
54
|
}
|
64
55
|
|
65
56
|
contract Registry is IRegistry {
|
@@ -73,37 +64,71 @@ contract Registry is IRegistry {
|
|
73
64
|
IChainNft private _chainNft;
|
74
65
|
|
75
66
|
function initialize(address chainNft) external {
|
76
|
-
require(
|
67
|
+
require(
|
68
|
+
address(_chainNft) == address(0),
|
69
|
+
"ERROR:REG-001:ALREADY_INITIALIZED"
|
70
|
+
);
|
77
71
|
_chainNft = IChainNft(chainNft);
|
78
72
|
}
|
79
73
|
|
80
|
-
function TOKEN() public pure override returns(uint256) {
|
81
|
-
|
82
|
-
|
83
|
-
function ORACLE() public pure override returns(uint256) { return 60; }
|
84
|
-
function POOL() public pure override returns(uint256) { return 70; }
|
85
|
-
function POLICY() public pure override returns(uint256) { return 80; }
|
86
|
-
function BUNDLE() public pure override returns(uint256) { return 90; }
|
74
|
+
function TOKEN() public pure override returns (uint256) {
|
75
|
+
return 30;
|
76
|
+
}
|
87
77
|
|
88
|
-
function
|
89
|
-
|
78
|
+
function INSTANCE() public pure override returns (uint256) {
|
79
|
+
return 40;
|
80
|
+
}
|
81
|
+
|
82
|
+
function PRODUCT() public pure override returns (uint256) {
|
83
|
+
return 50;
|
84
|
+
}
|
85
|
+
|
86
|
+
function ORACLE() public pure override returns (uint256) {
|
87
|
+
return 60;
|
88
|
+
}
|
89
|
+
|
90
|
+
function POOL() public pure override returns (uint256) {
|
91
|
+
return 70;
|
92
|
+
}
|
93
|
+
|
94
|
+
function POLICY() public pure override returns (uint256) {
|
95
|
+
return 80;
|
96
|
+
}
|
97
|
+
|
98
|
+
function BUNDLE() public pure override returns (uint256) {
|
99
|
+
return 90;
|
100
|
+
}
|
101
|
+
|
102
|
+
function register(
|
103
|
+
address objectAddress
|
104
|
+
) external override returns (NftId nftId) {
|
105
|
+
require(
|
106
|
+
_nftIdByAddress[objectAddress].eqz(),
|
107
|
+
"ERROR:REG-002:ALREADY_REGISTERED"
|
108
|
+
);
|
90
109
|
|
91
110
|
IRegisterable registerable = IRegisterable(objectAddress);
|
92
|
-
require(
|
111
|
+
require(
|
112
|
+
registerable.isRegisterable(),
|
113
|
+
"ERROR:REG-003:NOT_REGISTERABLE"
|
114
|
+
);
|
93
115
|
|
94
116
|
// check parent exists (for objects not instances)
|
95
|
-
if(registerable.getType() != INSTANCE()) {
|
96
|
-
RegistryInfo memory parentInfo = _info[
|
117
|
+
if (registerable.getType() != INSTANCE()) {
|
118
|
+
RegistryInfo memory parentInfo = _info[
|
119
|
+
registerable.getParentNftId()
|
120
|
+
];
|
97
121
|
require(parentInfo.nftId.gtz(), "ERROR:REG-004:PARENT_NOT_FOUND");
|
98
122
|
// check validity of parent relation, valid relations are
|
99
123
|
// policy -> product, bundle -> pool, product -> instance, pool -> instance
|
100
124
|
}
|
101
125
|
|
102
126
|
uint256 mintedTokenId = _chainNft.mint(
|
103
|
-
registerable.getInitialOwner(),
|
104
|
-
EMPTY_URI
|
127
|
+
registerable.getInitialOwner(),
|
128
|
+
EMPTY_URI
|
129
|
+
);
|
105
130
|
nftId = toNftId(mintedTokenId);
|
106
|
-
|
131
|
+
|
107
132
|
RegistryInfo memory info = RegistryInfo(
|
108
133
|
nftId,
|
109
134
|
registerable.getParentNftId(),
|
@@ -118,25 +143,25 @@ contract Registry is IRegistry {
|
|
118
143
|
// add logging
|
119
144
|
}
|
120
145
|
|
121
|
-
|
122
146
|
function registerObjectForInstance(
|
123
147
|
NftId parentNftId,
|
124
148
|
uint256 objectType,
|
125
149
|
address initialOwner
|
126
150
|
)
|
127
|
-
external
|
151
|
+
external
|
128
152
|
override
|
129
|
-
|
130
|
-
|
153
|
+
returns (
|
154
|
+
// TODO add onlyRegisteredInstance
|
155
|
+
NftId nftId
|
156
|
+
)
|
131
157
|
{
|
132
158
|
// TODO add more validation
|
133
159
|
require(
|
134
160
|
objectType == POLICY() || objectType == BUNDLE(),
|
135
|
-
"ERROR:REG-005:TYPE_INVALID"
|
161
|
+
"ERROR:REG-005:TYPE_INVALID"
|
162
|
+
);
|
136
163
|
|
137
|
-
uint256 mintedTokenId = _chainNft.mint(
|
138
|
-
initialOwner,
|
139
|
-
EMPTY_URI);
|
164
|
+
uint256 mintedTokenId = _chainNft.mint(initialOwner, EMPTY_URI);
|
140
165
|
nftId = toNftId(mintedTokenId);
|
141
166
|
|
142
167
|
RegistryInfo memory info = RegistryInfo(
|
@@ -152,31 +177,33 @@ contract Registry is IRegistry {
|
|
152
177
|
// add logging
|
153
178
|
}
|
154
179
|
|
155
|
-
|
156
|
-
function getObjectCount() external view override returns(uint256) {
|
180
|
+
function getObjectCount() external view override returns (uint256) {
|
157
181
|
return _chainNft.totalSupply();
|
158
182
|
}
|
159
183
|
|
160
|
-
|
161
|
-
|
184
|
+
function getNftId(
|
185
|
+
address object
|
186
|
+
) external view override returns (NftId id) {
|
162
187
|
return _nftIdByAddress[object];
|
163
188
|
}
|
164
189
|
|
165
|
-
|
166
|
-
|
190
|
+
function isRegistered(
|
191
|
+
address object
|
192
|
+
) external view override returns (bool) {
|
167
193
|
return _nftIdByAddress[object].gtz();
|
168
194
|
}
|
169
195
|
|
170
|
-
|
171
|
-
|
196
|
+
function getInfo(
|
197
|
+
NftId nftId
|
198
|
+
) external view override returns (RegistryInfo memory info) {
|
172
199
|
return _info[nftId];
|
173
200
|
}
|
174
201
|
|
175
|
-
function getOwner(NftId nftId) external view override returns(address) {
|
202
|
+
function getOwner(NftId nftId) external view override returns (address) {
|
176
203
|
return _chainNft.ownerOf(nftId.toInt());
|
177
204
|
}
|
178
205
|
|
179
|
-
function getNftAddress() external view override returns(address nft) {
|
206
|
+
function getNftAddress() external view override returns (address nft) {
|
180
207
|
return address(_chainNft);
|
181
208
|
}
|
182
209
|
}
|
@@ -14,47 +14,105 @@ using {
|
|
14
14
|
} for Blocknumber global;
|
15
15
|
|
16
16
|
/// @dev return true if Blocknumber a is greater than Blocknumber b
|
17
|
-
function gtBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
17
|
+
function gtBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
18
|
+
return Blocknumber.unwrap(a) > Blocknumber.unwrap(b);
|
19
|
+
}
|
20
|
+
|
18
21
|
/// @dev return true if Blocknumber a is greater than or equal to Blocknumber b
|
19
|
-
function gteBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
22
|
+
function gteBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
23
|
+
return Blocknumber.unwrap(a) >= Blocknumber.unwrap(b);
|
24
|
+
}
|
20
25
|
|
21
26
|
/// @dev return true if Blocknumber a is less than Blocknumber b
|
22
|
-
function ltBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
27
|
+
function ltBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
28
|
+
return Blocknumber.unwrap(a) < Blocknumber.unwrap(b);
|
29
|
+
}
|
30
|
+
|
23
31
|
/// @dev return true if Blocknumber a is less than or equal to Blocknumber b
|
24
|
-
function lteBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
32
|
+
function lteBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
33
|
+
return Blocknumber.unwrap(a) <= Blocknumber.unwrap(b);
|
34
|
+
}
|
25
35
|
|
26
36
|
/// @dev return true if Blocknumber a is equal to Blocknumber b
|
27
|
-
function eqBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
37
|
+
function eqBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
38
|
+
return Blocknumber.unwrap(a) == Blocknumber.unwrap(b);
|
39
|
+
}
|
40
|
+
|
28
41
|
/// @dev return true if Blocknumber a is not equal to Blocknumber b
|
29
|
-
function neBlocknumber(Blocknumber a, Blocknumber b) pure returns(bool) {
|
42
|
+
function neBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
|
43
|
+
return Blocknumber.unwrap(a) != Blocknumber.unwrap(b);
|
44
|
+
}
|
30
45
|
|
31
46
|
/// @dev Converts the uint256 to a Blocknumber.
|
32
|
-
function toBlocknumber(uint256 blocknum) pure returns(Blocknumber) {
|
47
|
+
function toBlocknumber(uint256 blocknum) pure returns (Blocknumber) {
|
48
|
+
return Blocknumber.wrap(uint32(blocknum));
|
49
|
+
}
|
33
50
|
|
34
|
-
function blockBlocknumber() view returns(Blocknumber) {
|
51
|
+
function blockBlocknumber() view returns (Blocknumber) {
|
52
|
+
return toBlocknumber(block.number);
|
53
|
+
}
|
35
54
|
|
36
55
|
/// @dev Return the Blocknumber zero (0)
|
37
|
-
function zeroBlocknumber() pure returns(Blocknumber) {
|
56
|
+
function zeroBlocknumber() pure returns (Blocknumber) {
|
57
|
+
return toBlocknumber(0);
|
58
|
+
}
|
38
59
|
|
39
60
|
/// @dev Return the current block number
|
40
|
-
function blockNumber() view returns(Blocknumber) {
|
61
|
+
function blockNumber() view returns (Blocknumber) {
|
62
|
+
return toBlocknumber(block.number);
|
63
|
+
}
|
41
64
|
|
42
65
|
library BlocknumberLib {
|
43
66
|
/// @dev return true if Blocknumber a is greater than Blocknumber b
|
44
|
-
function gt(
|
67
|
+
function gt(
|
68
|
+
Blocknumber a,
|
69
|
+
Blocknumber b
|
70
|
+
) public pure returns (bool isAfter) {
|
71
|
+
return gtBlocknumber(a, b);
|
72
|
+
}
|
73
|
+
|
45
74
|
/// @dev return true if Blocknumber a is greater than or equal to Blocknumber b
|
46
|
-
function gte(
|
47
|
-
|
75
|
+
function gte(
|
76
|
+
Blocknumber a,
|
77
|
+
Blocknumber b
|
78
|
+
) public pure returns (bool isAfterOrSame) {
|
79
|
+
return gteBlocknumber(a, b);
|
80
|
+
}
|
81
|
+
|
48
82
|
/// @dev return true if Blocknumber a is less than Blocknumber b
|
49
|
-
function lt(
|
83
|
+
function lt(
|
84
|
+
Blocknumber a,
|
85
|
+
Blocknumber b
|
86
|
+
) public pure returns (bool isBefore) {
|
87
|
+
return ltBlocknumber(a, b);
|
88
|
+
}
|
89
|
+
|
50
90
|
/// @dev return true if Blocknumber a is less than or equal to Blocknumber b
|
51
|
-
function lte(
|
91
|
+
function lte(
|
92
|
+
Blocknumber a,
|
93
|
+
Blocknumber b
|
94
|
+
) public pure returns (bool isBeforeOrSame) {
|
95
|
+
return lteBlocknumber(a, b);
|
96
|
+
}
|
52
97
|
|
53
98
|
/// @dev return true if Blocknumber a is equal to Blocknumber b
|
54
|
-
function eq(
|
99
|
+
function eq(
|
100
|
+
Blocknumber a,
|
101
|
+
Blocknumber b
|
102
|
+
) public pure returns (bool isSame) {
|
103
|
+
return eqBlocknumber(a, b);
|
104
|
+
}
|
105
|
+
|
55
106
|
/// @dev return true if Blocknumber a is not equal to Blocknumber b
|
56
|
-
function ne(
|
107
|
+
function ne(
|
108
|
+
Blocknumber a,
|
109
|
+
Blocknumber b
|
110
|
+
) public pure returns (bool isDifferent) {
|
111
|
+
return neBlocknumber(a, b);
|
112
|
+
}
|
57
113
|
|
58
114
|
/// @dev converts the Blocknumber to a uint256
|
59
|
-
function toInt(Blocknumber blocknumber) public pure returns(uint256) {
|
115
|
+
function toInt(Blocknumber blocknumber) public pure returns (uint256) {
|
116
|
+
return uint256(uint32(Blocknumber.unwrap(blocknumber)));
|
117
|
+
}
|
60
118
|
}
|