@etherisc/gif-next 0.0.2-ad36bbd → 0.0.2-cc253b3
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/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.json +7 -7
- 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/IPool.sol/IPoolComponent.json +6 -6
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +8 -8
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +29 -11
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +31 -13
- 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/IInstance.sol/IInstance.json +60 -60
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +114 -64
- 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/ComponentModule.json +24 -24
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +48 -6
- 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/IComponentContract.json +6 -6
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +26 -26
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +3 -3
- 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/IPolicy.sol/IPolicyModule.json +18 -18
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +18 -18
- 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/IPoolModule.sol/IPoolModule.json +10 -10
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.json +10 -10
- 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/IProductService.sol/IProductService.json +8 -8
- 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 +54 -12
- 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/IRegisterable.json +6 -6
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +16 -16
- 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/Registerable.json +7 -7
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +62 -20
- 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/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 +61 -3
- package/contracts/components/Component.sol +3 -3
- package/contracts/components/IProduct.sol +2 -1
- package/contracts/components/Product.sol +5 -4
- package/contracts/experiment/errors/Require.sol +2 -2
- package/contracts/instance/Instance.sol +4 -3
- package/contracts/instance/component/ComponentModule.sol +32 -43
- package/contracts/instance/component/IComponent.sol +11 -10
- package/contracts/instance/policy/IPolicy.sol +8 -8
- package/contracts/instance/policy/PolicyModule.sol +12 -11
- package/contracts/instance/pool/IPoolModule.sol +6 -5
- package/contracts/instance/pool/PoolModule.sol +9 -6
- package/contracts/instance/product/IProductService.sol +5 -4
- package/contracts/instance/product/ProductService.sol +14 -11
- package/contracts/registry/IRegistry.sol +13 -11
- package/contracts/registry/Registry.sol +28 -22
- package/contracts/types/NftId.sol +3 -2
- package/package.json +1 -1
@@ -3,6 +3,8 @@ pragma solidity ^0.8.19;
|
|
3
3
|
|
4
4
|
import {IChainNft} from "./IChainNft.sol";
|
5
5
|
import {IRegistry, IRegistryLinked, IRegisterable} from "./IRegistry.sol";
|
6
|
+
import {NftId, toNftId} from "../types/NftId.sol";
|
7
|
+
import {NftIdLib} from "../types/NftId.sol";
|
6
8
|
|
7
9
|
contract RegistryLinked is IRegistryLinked {
|
8
10
|
|
@@ -23,6 +25,7 @@ abstract contract Registerable is
|
|
23
25
|
RegistryLinked,
|
24
26
|
IRegisterable
|
25
27
|
{
|
28
|
+
using NftIdLib for NftId;
|
26
29
|
|
27
30
|
address private _initialOwner;
|
28
31
|
|
@@ -43,15 +46,16 @@ abstract contract Registerable is
|
|
43
46
|
}
|
44
47
|
|
45
48
|
function isRegistered() public view override returns(bool) {
|
46
|
-
|
49
|
+
NftId nftId = _registry.getNftId(address(this));
|
50
|
+
return nftId.gtz();
|
47
51
|
}
|
48
52
|
|
49
|
-
function getNftId() public view override returns(
|
53
|
+
function getNftId() public view override returns(NftId nftId) {
|
50
54
|
return _registry.getNftId(address(this));
|
51
55
|
}
|
52
56
|
|
53
57
|
function getOwner() public view override returns(address owner) {
|
54
|
-
|
58
|
+
NftId id = _registry.getNftId(address(this));
|
55
59
|
owner = _registry.getOwner(id);
|
56
60
|
return owner != address(0) ? owner : _initialOwner;
|
57
61
|
}
|
@@ -59,12 +63,12 @@ abstract contract Registerable is
|
|
59
63
|
}
|
60
64
|
|
61
65
|
contract Registry is IRegistry {
|
62
|
-
|
66
|
+
using NftIdLib for NftId;
|
63
67
|
string public constant EMPTY_URI = "";
|
64
68
|
|
65
|
-
mapping(
|
66
|
-
mapping(
|
67
|
-
mapping(address object =>
|
69
|
+
mapping(NftId nftId => RegistryInfo info) private _info;
|
70
|
+
mapping(NftId nftId => address owner) private _owner;
|
71
|
+
mapping(address object => NftId nftId) private _nftIdByAddress;
|
68
72
|
|
69
73
|
IChainNft private _chainNft;
|
70
74
|
|
@@ -81,23 +85,24 @@ contract Registry is IRegistry {
|
|
81
85
|
function POLICY() public pure override returns(uint256) { return 80; }
|
82
86
|
function BUNDLE() public pure override returns(uint256) { return 90; }
|
83
87
|
|
84
|
-
function register(address objectAddress) external override returns(
|
85
|
-
require(
|
88
|
+
function register(address objectAddress) external override returns(NftId nftId) {
|
89
|
+
require(_nftIdByAddress[objectAddress].eqz(), "ERROR:REG-002:ALREADY_REGISTERED");
|
86
90
|
|
87
91
|
IRegisterable registerable = IRegisterable(objectAddress);
|
88
|
-
require(registerable.isRegisterable(), "ERROR:REG-
|
92
|
+
require(registerable.isRegisterable(), "ERROR:REG-003:NOT_REGISTERABLE");
|
89
93
|
|
90
94
|
// check parent exists (for objects not instances)
|
91
95
|
if(registerable.getType() != INSTANCE()) {
|
92
96
|
RegistryInfo memory parentInfo = _info[registerable.getParentNftId()];
|
93
|
-
require(parentInfo.nftId
|
97
|
+
require(parentInfo.nftId.gtz(), "ERROR:REG-004:PARENT_NOT_FOUND");
|
94
98
|
// check validity of parent relation, valid relations are
|
95
99
|
// policy -> product, bundle -> pool, product -> instance, pool -> instance
|
96
100
|
}
|
97
101
|
|
98
|
-
|
102
|
+
uint256 mintedTokenId = _chainNft.mint(
|
99
103
|
registerable.getInitialOwner(),
|
100
104
|
EMPTY_URI);
|
105
|
+
nftId = toNftId(mintedTokenId);
|
101
106
|
|
102
107
|
RegistryInfo memory info = RegistryInfo(
|
103
108
|
nftId,
|
@@ -108,30 +113,31 @@ contract Registry is IRegistry {
|
|
108
113
|
);
|
109
114
|
|
110
115
|
_info[nftId] = info;
|
111
|
-
|
116
|
+
_nftIdByAddress[objectAddress] = nftId;
|
112
117
|
|
113
118
|
// add logging
|
114
119
|
}
|
115
120
|
|
116
121
|
|
117
122
|
function registerObjectForInstance(
|
118
|
-
|
123
|
+
NftId parentNftId,
|
119
124
|
uint256 objectType,
|
120
125
|
address initialOwner
|
121
126
|
)
|
122
127
|
external
|
123
128
|
override
|
124
129
|
// TODO add onlyRegisteredInstance
|
125
|
-
returns(
|
130
|
+
returns(NftId nftId)
|
126
131
|
{
|
127
132
|
// TODO add more validation
|
128
133
|
require(
|
129
134
|
objectType == POLICY() || objectType == BUNDLE(),
|
130
135
|
"ERROR:REG-005:TYPE_INVALID");
|
131
136
|
|
132
|
-
|
137
|
+
uint256 mintedTokenId = _chainNft.mint(
|
133
138
|
initialOwner,
|
134
139
|
EMPTY_URI);
|
140
|
+
nftId = toNftId(mintedTokenId);
|
135
141
|
|
136
142
|
RegistryInfo memory info = RegistryInfo(
|
137
143
|
nftId,
|
@@ -152,22 +158,22 @@ contract Registry is IRegistry {
|
|
152
158
|
}
|
153
159
|
|
154
160
|
|
155
|
-
function getNftId(address object) external view override returns(
|
156
|
-
return
|
161
|
+
function getNftId(address object) external view override returns(NftId id) {
|
162
|
+
return _nftIdByAddress[object];
|
157
163
|
}
|
158
164
|
|
159
165
|
|
160
166
|
function isRegistered(address object) external view override returns(bool) {
|
161
|
-
return
|
167
|
+
return _nftIdByAddress[object].gtz();
|
162
168
|
}
|
163
169
|
|
164
170
|
|
165
|
-
function getInfo(
|
171
|
+
function getInfo(NftId nftId) external view override returns(RegistryInfo memory info) {
|
166
172
|
return _info[nftId];
|
167
173
|
}
|
168
174
|
|
169
|
-
function getOwner(
|
170
|
-
return _chainNft.ownerOf(nftId);
|
175
|
+
function getOwner(NftId nftId) external view override returns(address) {
|
176
|
+
return _chainNft.ownerOf(nftId.toInt());
|
171
177
|
}
|
172
178
|
|
173
179
|
function getNftAddress() external view override returns(address nft) {
|
@@ -13,7 +13,6 @@ using {
|
|
13
13
|
|
14
14
|
// general pure free functions
|
15
15
|
function toNftId(uint256 id) pure returns(NftId) { return NftId.wrap(uint96(id)); }
|
16
|
-
function gtz(NftId a) pure returns(bool) { return NftId.unwrap(a) > 0; }
|
17
16
|
|
18
17
|
// pure free functions for operators
|
19
18
|
function eqNftId(NftId a, NftId b) pure returns(bool isSame) { return NftId.unwrap(a) == NftId.unwrap(b); }
|
@@ -21,5 +20,7 @@ function neNftId(NftId a, NftId b) pure returns(bool isDifferent) { return NftId
|
|
21
20
|
|
22
21
|
// library functions that operate on user defined type
|
23
22
|
library NftIdLib {
|
24
|
-
function toInt(NftId nftId)
|
23
|
+
function toInt(NftId nftId) public pure returns(uint256) { return uint256(NftId.unwrap(nftId)); }
|
24
|
+
function gtz(NftId a) public pure returns(bool) { return NftId.unwrap(a) > 0; }
|
25
|
+
function eqz(NftId a) public pure returns(bool) { return NftId.unwrap(a) == 0; }
|
25
26
|
}
|
package/package.json
CHANGED