@etherisc/gif-next 0.0.2-a0a9c3a-892 → 0.0.2-a0d433e-961

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 (164) hide show
  1. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
  2. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +16 -0
  3. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.json +34 -6
  5. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
  6. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +16 -0
  7. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  8. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  10. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  11. package/artifacts/contracts/components/Pool.sol/Pool.json +33 -5
  12. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  13. package/artifacts/contracts/components/Product.sol/Product.json +33 -5
  14. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +1 -1
  15. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +1 -1
  16. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +1 -1
  17. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  18. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  19. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  20. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  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/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
  29. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
  30. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
  31. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
  32. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  33. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  34. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +1 -1
  35. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  36. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +2 -2
  37. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
  38. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  39. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +13 -0
  40. package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
  41. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  42. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +57 -1
  43. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  44. package/artifacts/contracts/instance/Instance.sol/Instance.json +69 -603
  45. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
  46. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +266 -149
  47. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +1 -1
  48. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +2 -2
  49. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  50. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +2 -2
  51. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  52. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +143 -191
  53. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  54. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +36 -80
  55. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
  56. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +2 -2
  57. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
  58. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
  59. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  60. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  61. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  62. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  63. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  64. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +54 -22
  65. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  66. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  67. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  68. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  69. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
  70. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
  71. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
  72. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +2 -2
  73. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  74. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +2 -2
  75. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
  76. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +2 -2
  77. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
  78. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +2 -2
  79. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  80. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +2 -2
  81. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
  82. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
  83. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  84. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  85. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  86. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  87. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
  88. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +2 -2
  89. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  90. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +2 -2
  91. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
  92. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +2 -2
  93. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  94. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +2 -2
  95. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
  96. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +2 -2
  97. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
  98. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +2 -2
  99. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  100. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  101. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  102. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  103. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  104. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  105. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +2 -2
  106. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  107. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +2 -2
  108. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  109. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
  110. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  111. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  112. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  113. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  114. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  115. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  116. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  117. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  118. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +1 -1
  119. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  120. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  121. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  122. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  123. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  124. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  125. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  126. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +2 -2
  127. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  128. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  129. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  130. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  131. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  132. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  133. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  134. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  135. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  136. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  137. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  138. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  139. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  140. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
  141. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  142. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
  143. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  144. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  145. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
  146. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  147. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  148. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
  149. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
  150. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  151. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  152. package/contracts/components/BaseComponent.sol +16 -0
  153. package/contracts/components/IBaseComponent.sol +1 -0
  154. package/contracts/instance/IInstance.sol +2 -0
  155. package/contracts/instance/IInstanceService.sol +8 -2
  156. package/contracts/instance/Instance.sol +9 -198
  157. package/contracts/instance/InstanceAccessManager.sol +93 -77
  158. package/contracts/instance/InstanceService.sol +130 -91
  159. package/contracts/instance/module/IAccess.sol +27 -17
  160. package/contracts/types/RoleId.sol +6 -7
  161. package/package.json +1 -1
  162. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
  163. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
  164. package/contracts/instance/IAccessManagerSimple.sol +0 -391
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -75,8 +75,8 @@
75
75
  "type": "function"
76
76
  }
77
77
  ],
78
- "bytecode": "0x608060405234801561001057600080fd5b5061032e806100206000396000f3fe608060405234801561001057600080fd5b50600436106100575760003560e01c80631fa8a7301461005c5780635312fdc214610082578063775a404814610095578063b844f20e1461009d578063c4ce6e5b146100b2575b600080fd5b6100646100ba565b60405167ffffffffffffffff90911681526020015b60405180910390f35b610064610090366004610260565b6100c9565b610064610146565b6100a5610150565b6040516100799190610279565b6100a561017f565b60006100c46101ab565b905090565b6040516368aebf7b60e01b81526004810182905260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b90602401602060405180830381865af415801561011c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061014091906102c7565b92915050565b60006100c4610224565b60606100c460408051808201909152601081526f50726f647563744f776e6572526f6c6560801b602082015290565b60606100c460408051808201909152600d81526c506f6f6c4f776e6572526f6c6560981b602082015290565b6040516368aebf7b60e01b815261012c600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024015b602060405180830381865af4158015610200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906100c491906102c7565b6040516368aebf7b60e01b8152610190600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024016101e3565b60006020828403121561027257600080fd5b5035919050565b600060208083528351808285015260005b818110156102a65785810183015185820160400152820161028a565b506000604082860101526040601f19601f8301168501019250505092915050565b6000602082840312156102d957600080fd5b815167ffffffffffffffff811681146102f157600080fd5b939250505056fea2646970667358221220f0498e60b0f549ed85ef4b1ad50b93432af119e18d28746513c5fff7e2b2c98f64736f6c63430008140033",
79
- "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100575760003560e01c80631fa8a7301461005c5780635312fdc214610082578063775a404814610095578063b844f20e1461009d578063c4ce6e5b146100b2575b600080fd5b6100646100ba565b60405167ffffffffffffffff90911681526020015b60405180910390f35b610064610090366004610260565b6100c9565b610064610146565b6100a5610150565b6040516100799190610279565b6100a561017f565b60006100c46101ab565b905090565b6040516368aebf7b60e01b81526004810182905260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b90602401602060405180830381865af415801561011c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061014091906102c7565b92915050565b60006100c4610224565b60606100c460408051808201909152601081526f50726f647563744f776e6572526f6c6560801b602082015290565b60606100c460408051808201909152600d81526c506f6f6c4f776e6572526f6c6560981b602082015290565b6040516368aebf7b60e01b815261012c600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024015b602060405180830381865af4158015610200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906100c491906102c7565b6040516368aebf7b60e01b8152610190600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024016101e3565b60006020828403121561027257600080fd5b5035919050565b600060208083528351808285015260005b818110156102a65785810183015185820160400152820161028a565b506000604082860101526040601f19601f8301168501019250505092915050565b6000602082840312156102d957600080fd5b815167ffffffffffffffff811681146102f157600080fd5b939250505056fea2646970667358221220f0498e60b0f549ed85ef4b1ad50b93432af119e18d28746513c5fff7e2b2c98f64736f6c63430008140033",
78
+ "bytecode": "0x608060405234801561001057600080fd5b5061032e806100206000396000f3fe608060405234801561001057600080fd5b50600436106100575760003560e01c80631fa8a7301461005c5780635312fdc214610082578063775a404814610095578063b844f20e1461009d578063c4ce6e5b146100b2575b600080fd5b6100646100ba565b60405167ffffffffffffffff90911681526020015b60405180910390f35b610064610090366004610260565b6100c9565b610064610146565b6100a5610150565b6040516100799190610279565b6100a561017f565b60006100c46101ab565b905090565b6040516368aebf7b60e01b81526004810182905260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b90602401602060405180830381865af415801561011c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061014091906102c7565b92915050565b60006100c4610224565b60606100c460408051808201909152601081526f50726f647563744f776e6572526f6c6560801b602082015290565b60606100c460408051808201909152600d81526c506f6f6c4f776e6572526f6c6560981b602082015290565b6040516368aebf7b60e01b815261012c600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024015b602060405180830381865af4158015610200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906100c491906102c7565b6040516368aebf7b60e01b8152610190600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024016101e3565b60006020828403121561027257600080fd5b5035919050565b600060208083528351808285015260005b818110156102a65785810183015185820160400152820161028a565b506000604082860101526040601f19601f8301168501019250505092915050565b6000602082840312156102d957600080fd5b815167ffffffffffffffff811681146102f157600080fd5b939250505056fea2646970667358221220aec4b8d796f9feebeb896a45bad516fd50f73734922b9003d82834d4810dee3864736f6c63430008140033",
79
+ "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100575760003560e01c80631fa8a7301461005c5780635312fdc214610082578063775a404814610095578063b844f20e1461009d578063c4ce6e5b146100b2575b600080fd5b6100646100ba565b60405167ffffffffffffffff90911681526020015b60405180910390f35b610064610090366004610260565b6100c9565b610064610146565b6100a5610150565b6040516100799190610279565b6100a561017f565b60006100c46101ab565b905090565b6040516368aebf7b60e01b81526004810182905260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b90602401602060405180830381865af415801561011c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061014091906102c7565b92915050565b60006100c4610224565b60606100c460408051808201909152601081526f50726f647563744f776e6572526f6c6560801b602082015290565b60606100c460408051808201909152600d81526c506f6f6c4f776e6572526f6c6560981b602082015290565b6040516368aebf7b60e01b815261012c600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024015b602060405180830381865af4158015610200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906100c491906102c7565b6040516368aebf7b60e01b8152610190600482015260009073__$cd131c2b3ba46b9dbe046aaf4458b9777d$__906368aebf7b906024016101e3565b60006020828403121561027257600080fd5b5035919050565b600060208083528351808285015260005b818110156102a65785810183015185820160400152820161028a565b506000604082860101526040601f19601f8301168501019250505092915050565b6000602082840312156102d957600080fd5b815167ffffffffffffffff811681146102f157600080fd5b939250505056fea2646970667358221220aec4b8d796f9feebeb896a45bad516fd50f73734922b9003d82834d4810dee3864736f6c63430008140033",
80
80
  "linkReferences": {
81
81
  "contracts/types/RoleId.sol": {
82
82
  "RoleIdLib": [
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -131,8 +131,8 @@
131
131
  "type": "function"
132
132
  }
133
133
  ],
134
- "bytecode": "0x6102a461003a600b82828239805160001a60731461002d57634e487b7160e01b600052600060045260246000fd5b30600052607381538281f3fe73000000000000000000000000000000000000000030146080604052600436106100875760003560e01c806368aebf7b1161006557806368aebf7b14610119578063a42e52e914610127578063bc1b392d14610144578063f37f38f01461014b57600080fd5b8063057182b41461008c578063545ce21c146100bd57806367cb8ec1146100e7575b600080fd5b6100a861009a36600461020b565b67ffffffffffffffff161590565b60405190151581526020015b60405180910390f35b6100ce6100cb36600461020b565b90565b60405167ffffffffffffffff90911681526020016100b4565b6101066100f536600461020b565b60081b68ffffffffffffffff001690565b60405160ff1990911681526020016100b4565b6100ce6100cb36600461023c565b6100a861013536600461020b565b67ffffffffffffffff16151590565b60006100ce565b61015e61015936600461020b565b61016c565b6040519081526020016100b4565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce6014600885901b68ffffffffffffffff00166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af41580156101e1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102059190610255565b92915050565b60006020828403121561021d57600080fd5b813567ffffffffffffffff8116811461023557600080fd5b9392505050565b60006020828403121561024e57600080fd5b5035919050565b60006020828403121561026757600080fd5b505191905056fea2646970667358221220d05b76d7477b717f7dc69d7d48c31f6517affb9cfed8f56df2759e2ab290d86d64736f6c63430008140033",
135
- "deployedBytecode": "0x73000000000000000000000000000000000000000030146080604052600436106100875760003560e01c806368aebf7b1161006557806368aebf7b14610119578063a42e52e914610127578063bc1b392d14610144578063f37f38f01461014b57600080fd5b8063057182b41461008c578063545ce21c146100bd57806367cb8ec1146100e7575b600080fd5b6100a861009a36600461020b565b67ffffffffffffffff161590565b60405190151581526020015b60405180910390f35b6100ce6100cb36600461020b565b90565b60405167ffffffffffffffff90911681526020016100b4565b6101066100f536600461020b565b60081b68ffffffffffffffff001690565b60405160ff1990911681526020016100b4565b6100ce6100cb36600461023c565b6100a861013536600461020b565b67ffffffffffffffff16151590565b60006100ce565b61015e61015936600461020b565b61016c565b6040519081526020016100b4565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce6014600885901b68ffffffffffffffff00166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af41580156101e1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102059190610255565b92915050565b60006020828403121561021d57600080fd5b813567ffffffffffffffff8116811461023557600080fd5b9392505050565b60006020828403121561024e57600080fd5b5035919050565b60006020828403121561026757600080fd5b505191905056fea2646970667358221220d05b76d7477b717f7dc69d7d48c31f6517affb9cfed8f56df2759e2ab290d86d64736f6c63430008140033",
134
+ "bytecode": "0x6102a461003a600b82828239805160001a60731461002d57634e487b7160e01b600052600060045260246000fd5b30600052607381538281f3fe73000000000000000000000000000000000000000030146080604052600436106100875760003560e01c806368aebf7b1161006557806368aebf7b14610119578063a42e52e914610127578063bc1b392d14610144578063f37f38f01461014b57600080fd5b8063057182b41461008c578063545ce21c146100bd57806367cb8ec1146100e7575b600080fd5b6100a861009a36600461020b565b67ffffffffffffffff161590565b60405190151581526020015b60405180910390f35b6100ce6100cb36600461020b565b90565b60405167ffffffffffffffff90911681526020016100b4565b6101066100f536600461020b565b60081b68ffffffffffffffff001690565b60405160ff1990911681526020016100b4565b6100ce6100cb36600461023c565b6100a861013536600461020b565b67ffffffffffffffff16151590565b60006100ce565b61015e61015936600461020b565b61016c565b6040519081526020016100b4565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce6014600885901b68ffffffffffffffff00166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af41580156101e1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102059190610255565b92915050565b60006020828403121561021d57600080fd5b813567ffffffffffffffff8116811461023557600080fd5b9392505050565b60006020828403121561024e57600080fd5b5035919050565b60006020828403121561026757600080fd5b505191905056fea2646970667358221220e6da4e195af13d74e56914d541f886dd55d797b235ab4469472a1f760011469864736f6c63430008140033",
135
+ "deployedBytecode": "0x73000000000000000000000000000000000000000030146080604052600436106100875760003560e01c806368aebf7b1161006557806368aebf7b14610119578063a42e52e914610127578063bc1b392d14610144578063f37f38f01461014b57600080fd5b8063057182b41461008c578063545ce21c146100bd57806367cb8ec1146100e7575b600080fd5b6100a861009a36600461020b565b67ffffffffffffffff161590565b60405190151581526020015b60405180910390f35b6100ce6100cb36600461020b565b90565b60405167ffffffffffffffff90911681526020016100b4565b6101066100f536600461020b565b60081b68ffffffffffffffff001690565b60405160ff1990911681526020016100b4565b6100ce6100cb36600461023c565b6100a861013536600461020b565b67ffffffffffffffff16151590565b60006100ce565b61015e61015936600461020b565b61016c565b6040519081526020016100b4565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce6014600885901b68ffffffffffffffff00166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af41580156101e1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102059190610255565b92915050565b60006020828403121561021d57600080fd5b813567ffffffffffffffff8116811461023557600080fd5b9392505050565b60006020828403121561024e57600080fd5b5035919050565b60006020828403121561026757600080fd5b505191905056fea2646970667358221220e6da4e195af13d74e56914d541f886dd55d797b235ab4469472a1f760011469864736f6c63430008140033",
136
136
  "linkReferences": {
137
137
  "contracts/types/Key32.sol": {
138
138
  "Key32Lib": [
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../build-info/65b23548824c96d3a9cfdfbce93a388d.json"
3
+ "buildInfo": "../../../build-info/3aeca1e783f6b7abcbd89db88120eb92.json"
4
4
  }
@@ -3,12 +3,16 @@ pragma solidity ^0.8.20;
3
3
 
4
4
  import {IBaseComponent} from "./IBaseComponent.sol";
5
5
  import {IComponentOwnerService} from "../instance/service/IComponentOwnerService.sol";
6
+ import {IInstanceService} from "../instance/IInstanceService.sol";
6
7
  import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
7
8
  import {IInstance} from "../instance/IInstance.sol";
9
+ import {InstanceAccessManager} from "../instance/InstanceAccessManager.sol";
8
10
  import {IRegistry} from "../registry/IRegistry.sol";
9
11
  import {NftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
10
12
  import {ObjectType} from "../types/ObjectType.sol";
13
+ import {VersionLib} from "../types/Version.sol";
11
14
  import {Registerable} from "../shared/Registerable.sol";
15
+ import {RoleId, RoleIdLib} from "../types/RoleId.sol";
12
16
  import {SafeERC20} from "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
13
17
 
14
18
  abstract contract BaseComponent is
@@ -18,13 +22,23 @@ abstract contract BaseComponent is
18
22
  using NftIdLib for NftId;
19
23
 
20
24
  IComponentOwnerService internal _componentOwnerService;
25
+ IInstanceService internal _instanceService;
21
26
 
22
27
  address internal _deployer;
23
28
  address internal _wallet;
24
29
  IERC20Metadata internal _token;
25
30
  IInstance internal _instance;
31
+ InstanceAccessManager internal _instanceAccessManager;
26
32
  NftId internal _productNftId;
27
33
 
34
+ modifier onlyInstanceRole(uint64 roleIdNum) {
35
+ RoleId roleId = RoleIdLib.toRoleId(roleIdNum);
36
+ if( !_instanceAccessManager.hasRole(roleId, msg.sender)) {
37
+ revert ErrorBaseComponentUnauthorized(msg.sender, roleIdNum);
38
+ }
39
+ _;
40
+ }
41
+
28
42
  constructor(
29
43
  address registry,
30
44
  NftId instanceNftId,
@@ -39,12 +53,14 @@ abstract contract BaseComponent is
39
53
 
40
54
  IRegistry.ObjectInfo memory instanceInfo = getRegistry().getObjectInfo(instanceNftId);
41
55
  _instance = IInstance(instanceInfo.objectAddress);
56
+ _instanceAccessManager = _instance.getInstanceAccessManager();
42
57
  require(
43
58
  _instance.supportsInterface(type(IInstance).interfaceId),
44
59
  ""
45
60
  );
46
61
 
47
62
  _componentOwnerService = _instance.getComponentOwnerService();
63
+ _instanceService = IInstanceService(getRegistry().getServiceAddress("InstanceService", VersionLib.toVersion(3, 0, 0).toMajorPart()));
48
64
  _wallet = address(this);
49
65
  _token = IERC20Metadata(token);
50
66
 
@@ -10,6 +10,7 @@ import {NftId} from "../types/NftId.sol";
10
10
  interface IBaseComponent is IRegisterable {
11
11
  error ErrorBaseComponentWalletAddressIsSameAsCurrent(address newWallet);
12
12
  error ErrorBaseComponentWalletAllowanceTooSmall(address oldWallet, address newWallet, uint256 allowance, uint256 balance);
13
+ error ErrorBaseComponentUnauthorized(address caller, uint64 requiredRoleIdNum);
13
14
 
14
15
  event LogBaseComponentWalletAddressChanged(address newWallet);
15
16
  event LogBaseComponentWalletTokensTransferred(address from, address to, uint256 amount);
@@ -6,6 +6,7 @@ import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
6
6
  import {BundleManager} from "./BundleManager.sol";
7
7
  import {InstanceReader} from "./InstanceReader.sol";
8
8
 
9
+ import {InstanceAccessManager} from "./InstanceAccessManager.sol";
9
10
  import {IComponentOwnerService} from "./service/IComponentOwnerService.sol";
10
11
  import {IDistributionService} from "./service/IDistributionService.sol";
11
12
  import {IPoolService} from "./service/IPoolService.sol";
@@ -55,6 +56,7 @@ interface IInstance is IERC165, IKeyValueStore {
55
56
  function updatePolicy(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external;
56
57
  function updatePolicyState(NftId policyNftId, StateId newState) external;
57
58
 
59
+ function getInstanceAccessManager() external view returns (InstanceAccessManager);
58
60
  function getInstanceReader() external view returns (InstanceReader);
59
61
  function getBundleManager() external view returns (BundleManager);
60
62
  }
@@ -10,23 +10,29 @@ import {IRegistry} from "../registry/IRegistry.sol";
10
10
  import {IRegisterable} from "../shared/IRegisterable.sol";
11
11
  import {IBaseComponent} from "../components/IBaseComponent.sol";
12
12
 
13
- import {AccessManagerUpgradeableInitializeable} from "./AccessManagerUpgradeableInitializeable.sol";
13
+ import {InstanceAccessManager} from "./InstanceAccessManager.sol";
14
14
  import {Instance} from "./Instance.sol";
15
15
  import {InstanceReader} from "./InstanceReader.sol";
16
16
  import {BundleManager} from "./BundleManager.sol";
17
17
 
18
18
  interface IInstanceService is IService {
19
19
 
20
+ error ErrorInstanceServiceRequestUnauhorized(address caller);
21
+ error ErrorInstanceServiceNotInstanceOwner(address caller, NftId instanceNftId);
22
+
20
23
  event LogInstanceCloned(address clonedAccessManagerAddress, address clonedInstanceAddress, address clonedInstanceReaderAddress, NftId clonedInstanceNftId);
21
24
 
22
25
  function createInstanceClone()
23
26
  external
24
27
  returns (
25
- AccessManagerUpgradeableInitializeable clonedAccessManager,
28
+ InstanceAccessManager clonedAccessManager,
26
29
  Instance clonedInstance,
27
30
  NftId instanceNftId,
28
31
  InstanceReader clonedInstanceReader,
29
32
  BundleManager clonedBundleManager
30
33
  );
34
+
35
+ function hasRole(address account, RoleId role, address instanceAddress) external returns (bool);
36
+
31
37
  }
32
38
 
@@ -5,7 +5,6 @@ import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet
5
5
  import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
6
6
  import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
7
7
  import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
8
- import {AccessManagerUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagerUpgradeable.sol";
9
8
 
10
9
  import {IAccess} from "./module/IAccess.sol";
11
10
  import {IBundle} from "./module/IBundle.sol";
@@ -16,6 +15,7 @@ import {Key32, KeyId, Key32Lib} from "../types/Key32.sol";
16
15
  import {KeyValueStore} from "./base/KeyValueStore.sol";
17
16
  import {IInstance} from "./IInstance.sol";
18
17
  import {InstanceReader} from "./InstanceReader.sol";
18
+ import {InstanceAccessManager} from "./InstanceAccessManager.sol";
19
19
  import {BundleManager} from "./BundleManager.sol";
20
20
  import {NftId} from "../types/NftId.sol";
21
21
  import {NumberId} from "../types/NumberId.sol";
@@ -23,6 +23,7 @@ import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT,
23
23
  import {RiskId, RiskIdLib} from "../types/RiskId.sol";
24
24
  import {RoleId, RoleIdLib} from "../types/RoleId.sol";
25
25
  import {StateId, ACTIVE} from "../types/StateId.sol";
26
+ import {TimestampLib} from "../types/Timestamp.sol";
26
27
  import {ERC165} from "../shared/ERC165.sol";
27
28
  import {Registerable} from "../shared/Registerable.sol";
28
29
  import {ComponentOwnerService} from "./service/ComponentOwnerService.sol";
@@ -50,13 +51,7 @@ contract Instance is
50
51
 
51
52
  bool private _initialized;
52
53
 
53
- mapping(ShortString name => RoleId roleId) internal _role;
54
- mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
55
- RoleId [] internal _roles;
56
-
57
- mapping(ShortString name => address target) internal _target;
58
-
59
- AccessManagerUpgradeable internal _accessManager;
54
+ InstanceAccessManager internal _accessManager;
60
55
  InstanceReader internal _instanceReader;
61
56
  BundleManager internal _bundleManager;
62
57
 
@@ -68,136 +63,14 @@ contract Instance is
68
63
 
69
64
  __AccessManaged_init(accessManagerAddress);
70
65
 
71
- _accessManager = AccessManagerUpgradeable(accessManagerAddress);
72
- _createRole(RoleIdLib.toRoleId(ADMIN_ROLE), "AdminRole", false, false);
73
- _createRole(RoleIdLib.toRoleId(PUBLIC_ROLE), "PublicRole", false, false);
74
-
66
+ _accessManager = InstanceAccessManager(accessManagerAddress);
67
+
75
68
  _initializeRegisterable(registryAddress, registryNftId, INSTANCE(), false, initialOwner, "");
76
69
 
77
70
  _registerInterface(type(IInstance).interfaceId);
78
71
  _initialized = true;
79
72
  }
80
73
 
81
- //--- Role ------------------------------------------------------//
82
- function createStandardRole(RoleId roleId, string memory name) external restricted() {
83
- _createRole(roleId, name, false, true);
84
- }
85
-
86
- function createCustomRole(RoleId roleId, string memory name) external restricted() {
87
- _createRole(roleId, name, true, true);
88
- }
89
-
90
- function updateRole(RoleId roleId, string memory name, StateId newState) external restricted() {
91
- (bool isCustom,) = _validateRoleParameters(roleId, name, false);
92
- IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
93
- update(toRoleKey32(roleId), abi.encode(role), newState);
94
- }
95
-
96
- function updateRoleState(RoleId roleId, StateId newState) external restricted() {
97
- updateState(toRoleKey32(roleId), newState);
98
- }
99
-
100
- function grantRole(RoleId roleId, address member) external restricted() returns (bool granted) {
101
- Key32 roleKey = toRoleKey32(roleId);
102
-
103
- if (!exists(roleKey)) {
104
- revert IAccess.ErrorGrantNonexstentRole(roleId);
105
- }
106
-
107
- if (getState(roleKey) != ACTIVE()) {
108
- revert IAccess.ErrorRoleIdNotActive(roleId);
109
- }
110
-
111
- if (!EnumerableSet.contains(_roleMembers[roleId], member)) {
112
- _accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
113
- EnumerableSet.add(_roleMembers[roleId], member);
114
- return true;
115
- }
116
-
117
- return false;
118
- }
119
-
120
- function revokeRole(RoleId roleId, address member) external restricted() returns (bool revoked) {
121
- Key32 roleKey = toRoleKey32(roleId);
122
-
123
- if (!exists(roleKey)) {
124
- revert IAccess.ErrorRevokeNonexstentRole(roleId);
125
- }
126
-
127
- if (EnumerableSet.contains(_roleMembers[roleId], member)) {
128
- _accessManager.revokeRole(roleId.toInt(), member);
129
- EnumerableSet.remove(_roleMembers[roleId], member);
130
- return true;
131
- }
132
-
133
- return false;
134
- }
135
-
136
- /// @dev not restricted function by intention
137
- /// the restriction to role members is already enforced by the call to the access manger
138
- function renounceRole(RoleId roleId) external returns (bool revoked) {
139
- address member = msg.sender;
140
- Key32 roleKey = toRoleKey32(roleId);
141
-
142
- if (!exists(roleKey)) {
143
- revert IAccess.ErrorRenounceNonexstentRole(roleId);
144
- }
145
-
146
- if (EnumerableSet.contains(_roleMembers[roleId], member)) {
147
- _accessManager.renounceRole(roleId.toInt(), member);
148
- EnumerableSet.remove(_roleMembers[roleId], member);
149
- return true;
150
- }
151
-
152
- return false;
153
- }
154
-
155
- function roles() external view returns (uint256 numberOfRoles) {
156
- return _roles.length;
157
- }
158
-
159
- function getRoleId(uint256 idx) external view returns (RoleId roleId) {
160
- return _roles[idx];
161
- }
162
-
163
- function getRole(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
164
- return abi.decode(getData(roleId.toKey32()), (IAccess.RoleInfo));
165
- }
166
-
167
- function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
168
- return EnumerableSet.length(_roleMembers[roleId]);
169
- }
170
-
171
- function getRoleMember(RoleId roleId, uint256 idx) external view returns (address roleMember) {
172
- return EnumerableSet.at(_roleMembers[roleId], idx);
173
- }
174
-
175
- function _createRole(RoleId roleId, string memory name, bool isCustom, bool validateParameters) internal {
176
- if (validateParameters) {
177
- _validateRoleParameters(roleId, name, isCustom);
178
- }
179
-
180
- IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
181
- _role[role.name] = roleId;
182
- _roles.push(roleId);
183
-
184
- create(toRoleKey32(roleId), abi.encode(role));
185
- }
186
-
187
- //--- Target ------------------------------------------------------//
188
- function createTarget(address target, IAccess.TargetInfo memory targetInfo) external restricted() {
189
- _validateTargetParameters(target, targetInfo);
190
- create(toTargetKey32(target), abi.encode(targetInfo));
191
- }
192
-
193
- function setTargetClosed(address target, bool closed) external restricted() {
194
- if (!exists(toTargetKey32(target))) {
195
- revert IAccess.ErrorTargetDoesNotExist(target);
196
- }
197
-
198
- _accessManager.setTargetClosed(target, closed);
199
- }
200
-
201
74
  //--- ProductSetup ------------------------------------------------------//
202
75
  function createProductSetup(NftId productNftId, ISetup.ProductSetupInfo memory setup) external restricted() {
203
76
  create(_toNftKey32(productNftId, PRODUCT()), abi.encode(setup));
@@ -342,71 +215,6 @@ contract Instance is
342
215
  }
343
216
 
344
217
  //--- internal view/pure functions --------------------------------------//
345
- function _toRole(RoleId roleId, string memory name, bool isCustom)
346
- internal
347
- pure
348
- returns (IAccess.RoleInfo memory role)
349
- {
350
- return IAccess.RoleInfo(
351
- ShortStrings.toShortString(name),
352
- isCustom);
353
- }
354
-
355
- function _validateRoleParameters(
356
- RoleId roleId,
357
- string memory name,
358
- bool isCustom
359
- )
360
- internal
361
- view
362
- returns (
363
- bool roleExists,
364
- bool roleIsCustom
365
- )
366
- {
367
- Key32 roleKey = toRoleKey32(roleId);
368
- roleExists = exists(roleKey);
369
- if (roleExists) {
370
- roleIsCustom = abi.decode(getData(roleKey), (IAccess.RoleInfo)).isCustom;
371
- } else {
372
- roleIsCustom = isCustom;
373
- }
374
-
375
- // check role id
376
- uint64 roleIdInt = RoleId.unwrap(roleId);
377
- if(roleIdInt == ADMIN_ROLE || roleIdInt == PUBLIC_ROLE) {
378
- revert IAccess.ErrorRoleIdInvalid(roleId);
379
- }
380
-
381
- if (roleIsCustom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
382
- revert IAccess.ErrorRoleIdTooSmall(roleId);
383
- } else if (roleIsCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
384
- revert IAccess.ErrorRoleIdTooBig(roleId);
385
- }
386
-
387
- // role name checks
388
- ShortString nameShort = ShortStrings.toShortString(name);
389
- if (ShortStrings.byteLength(nameShort) == 0) {
390
- revert IAccess.ErrorRoleNameEmpty(roleId);
391
- }
392
-
393
- if (_role[nameShort] != RoleIdLib.zero() && _role[nameShort] != roleId) {
394
- revert IAccess.ErrorRoleNameNotUnique(_role[nameShort], nameShort);
395
- }
396
- }
397
-
398
- function _validateTargetParameters(address target, IAccess.TargetInfo memory targetInfo) internal view {
399
-
400
- }
401
-
402
- function toRoleKey32(RoleId roleId) public pure returns (Key32) {
403
- return roleId.toKey32();
404
- }
405
-
406
- function toTargetKey32(address target) public pure returns (Key32) {
407
- return Key32Lib.toKey32(TARGET(), KeyId.wrap(bytes20(target)));
408
- }
409
-
410
218
  function _toNftKey32(NftId nftId, ObjectType objectType) internal pure returns (Key32) {
411
219
  return nftId.toKey32(objectType);
412
220
  }
@@ -443,8 +251,11 @@ contract Instance is
443
251
  return IBundleService(_registry.getServiceAddress("BundleService", VersionPart.wrap(3)));
444
252
  }
445
253
 
254
+ function getInstanceAccessManager() external view returns (InstanceAccessManager) {
255
+ return _accessManager;
256
+ }
257
+
446
258
  function setInstanceReader(InstanceReader instanceReader) external restricted() {
447
- require(address(_instanceReader) == address(0), "InstanceReader is set");
448
259
  require(instanceReader.getInstanceNftId() == getNftId(), "NFT ID of InstanceReader does not match");
449
260
  _instanceReader = instanceReader;
450
261
  }