@etherisc/gif-next 0.0.2-ad36bbd → 0.0.2-cc253b3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (103) hide show
  1. package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
  2. package/artifacts/contracts/components/Component.sol/Component.json +7 -7
  3. package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +1 -1
  4. package/artifacts/contracts/components/Component.sol/InstanceLinked.json +2 -2
  5. package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +1 -1
  6. package/artifacts/contracts/components/IPool.sol/IPoolComponent.json +6 -6
  7. package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
  8. package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +8 -8
  9. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  10. package/artifacts/contracts/components/Pool.sol/Pool.json +29 -11
  11. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  12. package/artifacts/contracts/components/Product.sol/Product.json +31 -13
  13. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  14. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
  15. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  16. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
  17. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  18. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
  19. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  20. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
  21. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
  22. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
  23. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
  24. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
  25. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
  26. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
  27. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
  29. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  30. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
  31. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  32. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +60 -60
  33. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  34. package/artifacts/contracts/instance/Instance.sol/Instance.json +114 -64
  35. package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +1 -1
  36. package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +1 -1
  37. package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +1 -1
  38. package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +1 -1
  39. package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +1 -1
  40. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
  41. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.json +24 -24
  42. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
  43. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +48 -6
  44. package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +1 -1
  45. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +1 -1
  46. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.json +6 -6
  47. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
  48. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +26 -26
  49. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
  50. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +3 -3
  51. package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +1 -1
  52. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
  53. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
  54. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.json +18 -18
  55. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
  56. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +18 -18
  57. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +1 -1
  58. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
  59. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.json +10 -10
  60. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
  61. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.json +10 -10
  62. package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +1 -1
  63. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +1 -1
  64. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.json +8 -8
  65. package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +1 -1
  66. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +1 -1
  67. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +54 -12
  68. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  69. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  70. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
  71. package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +1 -1
  72. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +1 -1
  73. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.json +6 -6
  74. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  75. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +16 -16
  76. package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +1 -1
  77. package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +1 -1
  78. package/artifacts/contracts/registry/Registry.sol/Registerable.json +7 -7
  79. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  80. package/artifacts/contracts/registry/Registry.sol/Registry.json +62 -20
  81. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +1 -1
  82. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +2 -2
  83. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  84. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
  85. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  86. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +61 -3
  87. package/contracts/components/Component.sol +3 -3
  88. package/contracts/components/IProduct.sol +2 -1
  89. package/contracts/components/Product.sol +5 -4
  90. package/contracts/experiment/errors/Require.sol +2 -2
  91. package/contracts/instance/Instance.sol +4 -3
  92. package/contracts/instance/component/ComponentModule.sol +32 -43
  93. package/contracts/instance/component/IComponent.sol +11 -10
  94. package/contracts/instance/policy/IPolicy.sol +8 -8
  95. package/contracts/instance/policy/PolicyModule.sol +12 -11
  96. package/contracts/instance/pool/IPoolModule.sol +6 -5
  97. package/contracts/instance/pool/PoolModule.sol +9 -6
  98. package/contracts/instance/product/IProductService.sol +5 -4
  99. package/contracts/instance/product/ProductService.sol +14 -11
  100. package/contracts/registry/IRegistry.sol +13 -11
  101. package/contracts/registry/Registry.sol +28 -22
  102. package/contracts/types/NftId.sol +3 -2
  103. 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
- return _registry.getNftId(address(this)) > 0;
49
+ NftId nftId = _registry.getNftId(address(this));
50
+ return nftId.gtz();
47
51
  }
48
52
 
49
- function getNftId() public view override returns(uint256 id) {
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
- uint256 id = _registry.getNftId(address(this));
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(uint256 id => RegistryInfo info) private _info;
66
- mapping(uint256 id => address owner) private _owner;
67
- mapping(address object => uint256 id) private _idByAddress;
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(uint256 nftId) {
85
- require(_idByAddress[objectAddress] == 0, "ERROR:REG-001:ALREADY_REGISTERED");
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-002:NOT_REGISTERABLE");
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 > 0, "ERROR:REG-003:PARENT_NOT_FOUND");
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
- nftId = _chainNft.mint(
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
- _idByAddress[objectAddress] = nftId;
116
+ _nftIdByAddress[objectAddress] = nftId;
112
117
 
113
118
  // add logging
114
119
  }
115
120
 
116
121
 
117
122
  function registerObjectForInstance(
118
- uint256 parentNftId,
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(uint256 nftId)
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
- nftId = _chainNft.mint(
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(uint256 id) {
156
- return _idByAddress[object];
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 _idByAddress[object] > 0;
167
+ return _nftIdByAddress[object].gtz();
162
168
  }
163
169
 
164
170
 
165
- function getInfo(uint256 nftId) external view override returns(RegistryInfo memory info) {
171
+ function getInfo(NftId nftId) external view override returns(RegistryInfo memory info) {
166
172
  return _info[nftId];
167
173
  }
168
174
 
169
- function getOwner(uint256 nftId) external view override returns(address) {
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) internal pure returns(uint256) { return uint256(NftId.unwrap(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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@etherisc/gif-next",
3
- "version": "0.0.2-ad36bbd",
3
+ "version": "0.0.2-cc253b3",
4
4
  "description": "This is the repository for the next version of the Generic Insurance Framework (GIF) smart contracts. ",
5
5
  "main": "index.js",
6
6
  "scripts": {