@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.
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": {