@etherisc/gif-next 0.0.2-fca9315-260 → 0.0.2-fd4931b-974

Sign up to get free protection for your applications and to get access to all the features.
Files changed (535) hide show
  1. package/README.md +8 -13
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1410 -0
  4. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  5. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1343 -0
  6. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  7. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +799 -0
  8. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  9. package/artifacts/contracts/{components/Pool.sol/Pool.json → distribution/IDistributionComponent.sol/IDistributionComponent.json} +366 -367
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +808 -0
  12. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +68 -54
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +267 -1594
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +285 -211
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +412 -2526
  20. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
  21. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +480 -166
  22. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
  23. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +132 -0
  24. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  25. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +610 -421
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +438 -399
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +348 -106
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3468 -0
  32. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  33. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  34. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  35. package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
  36. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
  38. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  39. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +58 -75
  40. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  41. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  42. package/artifacts/contracts/instance/module/{ISetup.sol/ISetup.json → IComponents.sol/IComponents.json} +2 -2
  43. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  44. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  45. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  46. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  47. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  48. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  49. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1091 -0
  50. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  51. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +723 -0
  52. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  53. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +257 -288
  54. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  55. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +565 -186
  56. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  57. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1044 -0
  58. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  59. package/artifacts/contracts/pool/Pool.sol/Pool.json +1559 -0
  60. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  61. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1411 -0
  62. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  63. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +719 -0
  64. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  65. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +820 -0
  66. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  67. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +699 -0
  68. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  69. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1264 -0
  70. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  71. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +787 -0
  72. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  73. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IApplicationService.sol/IApplicationService.json} +211 -212
  74. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  75. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
  76. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  77. package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +237 -302
  78. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  79. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +530 -0
  80. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  81. package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +351 -311
  82. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  83. package/artifacts/contracts/{instance/service/IDistributionService.sol/IDistributionService.json → product/IProductService.sol/IProductService.json} +112 -172
  84. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  85. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1132 -0
  86. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  87. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +731 -0
  88. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  89. package/artifacts/contracts/product/PricingService.sol/PricingService.json +969 -0
  90. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  91. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +755 -0
  92. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  93. package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → product/Product.sol/Product.json} +857 -214
  94. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  95. package/artifacts/contracts/product/ProductService.sol/ProductService.json +673 -0
  96. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  97. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +675 -0
  98. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  99. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
  100. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  101. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +158 -13
  102. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  103. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +337 -225
  104. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  105. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  106. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  107. package/artifacts/contracts/registry/Registry.sol/Registry.json +277 -30
  108. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
  109. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +74 -61
  110. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  111. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +465 -267
  112. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  113. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +334 -93
  114. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  115. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +634 -69
  116. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
  117. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
  118. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  119. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +448 -50
  120. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
  121. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
  122. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  123. package/artifacts/contracts/{components/Distribution.sol/Distribution.json → shared/Component.sol/Component.json} +321 -280
  124. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  125. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1461 -0
  126. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  127. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +765 -0
  128. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  129. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +215 -226
  130. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  131. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  132. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  133. package/artifacts/contracts/{components/IDistributionComponent.sol/IDistributionComponent.json → shared/IComponent.sol/IComponent.json} +205 -228
  134. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  135. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +854 -0
  136. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  137. package/artifacts/contracts/{components/Component.sol/Component.json → shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json} +203 -160
  138. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  139. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -1
  140. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  141. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  142. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  143. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +27 -29
  144. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  145. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
  146. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  147. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -29
  148. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  149. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
  150. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  151. package/artifacts/contracts/shared/IService.sol/IService.json +71 -160
  152. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  153. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  154. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  155. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1030 -0
  156. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  157. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +581 -0
  158. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  159. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  160. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  161. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +314 -0
  162. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  163. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +102 -35
  164. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  165. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
  166. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  167. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +310 -74
  168. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  169. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +125 -60
  170. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  171. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
  172. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  173. package/artifacts/contracts/shared/Service.sol/Service.json +172 -160
  174. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  175. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  176. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  177. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  178. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  179. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  180. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  181. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1770 -0
  182. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  183. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → staking/IStakingService.sol/IStakingService.json} +261 -238
  184. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  185. package/artifacts/contracts/staking/Staking.sol/Staking.json +2500 -0
  186. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  187. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +844 -0
  188. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  189. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +263 -0
  190. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  191. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +960 -0
  192. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  193. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +694 -0
  194. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  195. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +308 -0
  196. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  197. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  198. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  199. package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
  200. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  201. package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +16 -3
  202. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  203. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  204. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  205. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  206. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  207. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  208. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  209. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  210. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  211. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +185 -0
  212. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  213. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  214. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  215. package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
  216. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  217. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  218. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  219. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  220. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  221. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  222. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  223. package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
  224. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  225. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +148 -0
  226. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  227. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  228. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  229. package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
  230. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  231. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  232. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  233. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  234. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  235. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  236. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  237. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  238. package/contracts/distribution/Distribution.sol +263 -0
  239. package/contracts/distribution/DistributionService.sol +298 -0
  240. package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +15 -12
  241. package/contracts/distribution/IDistributionComponent.sol +66 -0
  242. package/contracts/distribution/IDistributionService.sol +81 -0
  243. package/contracts/instance/BundleManager.sol +15 -14
  244. package/contracts/instance/IInstance.sol +49 -44
  245. package/contracts/instance/IInstanceService.sol +57 -15
  246. package/contracts/instance/Instance.sol +138 -179
  247. package/contracts/instance/InstanceAccessManager.sol +406 -161
  248. package/contracts/instance/InstanceAuthorizationsLib.sol +336 -0
  249. package/contracts/instance/InstanceReader.sol +135 -62
  250. package/contracts/instance/InstanceService.sol +240 -305
  251. package/contracts/instance/InstanceServiceManager.sol +12 -22
  252. package/contracts/instance/InstanceStore.sol +260 -0
  253. package/contracts/instance/base/BalanceStore.sol +118 -0
  254. package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
  255. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +12 -14
  256. package/contracts/instance/module/IAccess.sol +24 -18
  257. package/contracts/instance/module/IBundle.sol +8 -8
  258. package/contracts/instance/module/IComponents.sol +52 -0
  259. package/contracts/instance/module/IDistribution.sol +7 -4
  260. package/contracts/instance/module/IPolicy.sol +56 -17
  261. package/contracts/instance/module/IRisk.sol +1 -1
  262. package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
  263. package/contracts/pool/BundleService.sol +296 -0
  264. package/contracts/pool/BundleServiceManager.sol +42 -0
  265. package/contracts/pool/IBundleService.sol +106 -0
  266. package/contracts/pool/IPoolComponent.sol +112 -0
  267. package/contracts/pool/IPoolService.sol +147 -0
  268. package/contracts/pool/Pool.sol +299 -0
  269. package/contracts/pool/PoolService.sol +424 -0
  270. package/contracts/pool/PoolServiceManager.sol +42 -0
  271. package/contracts/product/ApplicationService.sol +254 -0
  272. package/contracts/product/ApplicationServiceManager.sol +38 -0
  273. package/contracts/product/ClaimService.sol +437 -0
  274. package/contracts/product/ClaimServiceManager.sol +38 -0
  275. package/contracts/product/IApplicationService.sol +62 -0
  276. package/contracts/product/IClaimService.sol +93 -0
  277. package/contracts/product/IPolicyService.sol +78 -0
  278. package/contracts/product/IPricingService.sol +39 -0
  279. package/contracts/product/IProductComponent.sol +42 -0
  280. package/contracts/product/IProductService.sol +33 -0
  281. package/contracts/product/PolicyService.sol +473 -0
  282. package/contracts/product/PolicyServiceManager.sol +42 -0
  283. package/contracts/product/PricingService.sol +301 -0
  284. package/contracts/product/PricingServiceManager.sol +42 -0
  285. package/contracts/product/Product.sol +377 -0
  286. package/contracts/product/ProductService.sol +124 -0
  287. package/contracts/product/ProductServiceManager.sol +42 -0
  288. package/contracts/registry/ChainNft.sol +15 -1
  289. package/contracts/registry/IRegistry.sol +38 -18
  290. package/contracts/registry/IRegistryService.sol +41 -38
  291. package/contracts/registry/ITransferInterceptor.sol +1 -0
  292. package/contracts/registry/Registry.sol +193 -82
  293. package/contracts/registry/RegistryAccessManager.sol +72 -121
  294. package/contracts/registry/RegistryService.sol +164 -98
  295. package/contracts/registry/RegistryServiceManager.sol +28 -18
  296. package/contracts/registry/ReleaseManager.sol +390 -192
  297. package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
  298. package/contracts/registry/TokenRegistry.sol +263 -56
  299. package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
  300. package/contracts/shared/Component.sol +286 -0
  301. package/contracts/shared/ComponentService.sol +595 -0
  302. package/contracts/shared/ComponentServiceManager.sol +35 -0
  303. package/contracts/shared/ComponentVerifyingService.sol +111 -0
  304. package/contracts/shared/ERC165.sol +14 -12
  305. package/contracts/shared/IComponent.sol +74 -0
  306. package/contracts/shared/IComponentService.sol +91 -0
  307. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  308. package/contracts/{instance/base → shared}/IKeyValueStore.sol +14 -10
  309. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
  310. package/contracts/shared/INftOwnable.sol +12 -11
  311. package/contracts/shared/IPolicyHolder.sol +45 -0
  312. package/contracts/shared/IRegisterable.sol +3 -3
  313. package/contracts/shared/IRegistryLinked.sol +11 -0
  314. package/contracts/shared/IService.sol +6 -4
  315. package/contracts/shared/IVersionable.sol +5 -48
  316. package/contracts/shared/InstanceLinkedComponent.sol +145 -0
  317. package/contracts/shared/KeyValueStore.sol +130 -0
  318. package/contracts/{instance/base → shared}/Lifecycle.sol +28 -7
  319. package/contracts/shared/NftIdSetManager.sol +69 -0
  320. package/contracts/shared/NftOwnable.sol +64 -85
  321. package/contracts/shared/PolicyHolder.sol +101 -0
  322. package/contracts/shared/ProxyManager.sol +126 -25
  323. package/contracts/shared/Registerable.sol +19 -30
  324. package/contracts/shared/RegistryLinked.sol +43 -0
  325. package/contracts/shared/Service.sol +37 -20
  326. package/contracts/shared/TokenHandler.sol +37 -6
  327. package/contracts/shared/Versionable.sol +4 -92
  328. package/contracts/staking/IStaking.sol +113 -0
  329. package/contracts/staking/IStakingService.sol +122 -0
  330. package/contracts/staking/Staking.sol +348 -0
  331. package/contracts/staking/StakingManager.sol +52 -0
  332. package/contracts/staking/StakingReader.sol +92 -0
  333. package/contracts/staking/StakingService.sol +294 -0
  334. package/contracts/staking/StakingServiceManager.sol +44 -0
  335. package/contracts/staking/TargetManagerLib.sol +141 -0
  336. package/contracts/type/Amount.sol +114 -0
  337. package/contracts/{types → type}/Blocknumber.sol +7 -1
  338. package/contracts/type/ClaimId.sol +75 -0
  339. package/contracts/{types → type}/DistributorType.sol +2 -2
  340. package/contracts/{types → type}/Fee.sol +32 -22
  341. package/contracts/{types → type}/NftId.sol +17 -11
  342. package/contracts/{types → type}/NftIdSet.sol +1 -1
  343. package/contracts/{types → type}/ObjectType.sol +26 -9
  344. package/contracts/type/PayoutId.sol +82 -0
  345. package/contracts/{types → type}/Referral.sol +4 -0
  346. package/contracts/type/RoleId.sol +143 -0
  347. package/contracts/type/Seconds.sol +63 -0
  348. package/contracts/{types → type}/StateId.sol +24 -6
  349. package/contracts/{types → type}/Timestamp.sol +18 -13
  350. package/contracts/{types → type}/UFixed.sol +1 -0
  351. package/contracts/{types → type}/Version.sol +1 -0
  352. package/package.json +3 -3
  353. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  354. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  355. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  356. package/artifacts/contracts/components/IComponent.sol/IComponent.json +0 -455
  357. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  358. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  359. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  360. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  361. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  362. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
  363. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
  364. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
  365. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
  366. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
  367. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
  368. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  369. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  370. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  371. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  372. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  373. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  374. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  375. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  376. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  377. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  378. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  379. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  380. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  381. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  382. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  383. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  384. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  385. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  386. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  387. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  388. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  389. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  390. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  391. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  392. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  393. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  394. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  395. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  396. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  397. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  398. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  399. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  400. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  401. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  402. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  403. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
  404. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  405. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  406. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  407. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  408. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
  409. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  410. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  411. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  412. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  413. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  414. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  415. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1102
  416. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  417. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -449
  418. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  419. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -772
  420. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  421. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -437
  422. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  423. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  424. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  425. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  426. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  427. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  428. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1227
  429. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  430. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -505
  431. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  432. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -806
  433. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  434. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -437
  435. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  436. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -856
  437. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  438. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -437
  439. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  440. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  441. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  442. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  443. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  444. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -313
  445. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  446. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  447. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  448. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -608
  449. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  450. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  451. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  452. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  453. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  454. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
  455. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  456. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  457. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  458. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  459. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  460. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  461. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  462. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  463. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  464. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  465. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  466. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  467. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  468. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  469. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  470. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  471. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  472. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
  473. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  474. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  475. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  476. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  477. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  478. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  479. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  480. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  481. package/contracts/components/Component.sol +0 -216
  482. package/contracts/components/Distribution.sol +0 -150
  483. package/contracts/components/IComponent.sol +0 -43
  484. package/contracts/components/IDistributionComponent.sol +0 -47
  485. package/contracts/components/IPoolComponent.sol +0 -60
  486. package/contracts/components/IProductComponent.sol +0 -39
  487. package/contracts/components/Pool.sol +0 -227
  488. package/contracts/components/Product.sol +0 -265
  489. package/contracts/experiment/cloning/Cloner.sol +0 -47
  490. package/contracts/experiment/errors/Require.sol +0 -38
  491. package/contracts/experiment/errors/Revert.sol +0 -44
  492. package/contracts/experiment/inheritance/A.sol +0 -53
  493. package/contracts/experiment/inheritance/B.sol +0 -28
  494. package/contracts/experiment/inheritance/C.sol +0 -34
  495. package/contracts/experiment/inheritance/IA.sol +0 -13
  496. package/contracts/experiment/inheritance/IB.sol +0 -10
  497. package/contracts/experiment/inheritance/IC.sol +0 -12
  498. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  499. package/contracts/experiment/statemachine/ISM.sol +0 -25
  500. package/contracts/experiment/statemachine/SM.sol +0 -57
  501. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  502. package/contracts/experiment/types/TypeA.sol +0 -47
  503. package/contracts/experiment/types/TypeB.sol +0 -29
  504. package/contracts/instance/base/ComponentService.sol +0 -134
  505. package/contracts/instance/base/KeyValueStore.sol +0 -172
  506. package/contracts/instance/module/ISetup.sol +0 -46
  507. package/contracts/instance/module/ITreasury.sol +0 -23
  508. package/contracts/instance/service/BundleService.sol +0 -293
  509. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  510. package/contracts/instance/service/DistributionService.sol +0 -106
  511. package/contracts/instance/service/IBundleService.sol +0 -44
  512. package/contracts/instance/service/IDistributionService.sol +0 -12
  513. package/contracts/instance/service/IPolicyService.sol +0 -94
  514. package/contracts/instance/service/IPoolService.sol +0 -20
  515. package/contracts/instance/service/IProductService.sol +0 -40
  516. package/contracts/instance/service/PolicyService.sol +0 -538
  517. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  518. package/contracts/instance/service/PoolService.sol +0 -110
  519. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  520. package/contracts/instance/service/ProductService.sol +0 -234
  521. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  522. package/contracts/shared/ContractDeployerLib.sol +0 -72
  523. package/contracts/test/TestFee.sol +0 -25
  524. package/contracts/test/TestRegisterable.sol +0 -18
  525. package/contracts/test/TestRoleId.sol +0 -14
  526. package/contracts/test/TestService.sol +0 -25
  527. package/contracts/test/TestVersion.sol +0 -44
  528. package/contracts/test/TestVersionable.sol +0 -17
  529. package/contracts/test/Usdc.sol +0 -26
  530. package/contracts/types/ChainId.sol +0 -38
  531. package/contracts/types/NumberId.sol +0 -52
  532. package/contracts/types/RoleId.sol +0 -90
  533. /package/contracts/{types → type}/AddressSet.sol +0 -0
  534. /package/contracts/{types → type}/Key32.sol +0 -0
  535. /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,291 +1,536 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {AccessManager} from "@openzeppelin/contracts/access/manager/AccessManager.sol";
5
4
  import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
6
5
  import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
7
6
  import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
8
7
 
9
- import {RoleId, RoleIdLib } from "../types/RoleId.sol";
10
- import {TimestampLib} from "../types/Timestamp.sol";
8
+ import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE, INSTANCE_SERVICE_ROLE, INSTANCE_OWNER_ROLE, INSTANCE_ROLE} from "../type/RoleId.sol";
9
+ import {TimestampLib} from "../type/Timestamp.sol";
10
+ import {NftId} from "../type/NftId.sol";
11
+
12
+ import {AccessManagerUpgradeableInitializeable} from "../shared/AccessManagerUpgradeableInitializeable.sol";
13
+
14
+ import {IRegistry} from "../registry/IRegistry.sol";
15
+
16
+ import {IInstance} from "./IInstance.sol";
11
17
  import {IAccess} from "./module/IAccess.sol";
12
18
 
13
19
  contract InstanceAccessManager is
14
20
  AccessManagedUpgradeable
15
21
  {
22
+ event LogRoleCreation(RoleId roleId, ShortString name, IAccess.Type rtype);
23
+ event LogTargetCreation(address target, ShortString name, IAccess.Type ttype, bool isLocked);
24
+
16
25
  using RoleIdLib for RoleId;
17
26
 
18
27
  string public constant ADMIN_ROLE_NAME = "AdminRole";
19
28
  string public constant PUBLIC_ROLE_NAME = "PublicRole";
29
+ string public constant INSTANCE_ROLE_NAME = "InstanceRole";
30
+ string public constant INSTANCE_OWNER_ROLE_NAME = "InstanceOwnerRole";
20
31
 
21
- uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
32
+ uint64 public constant CUSTOM_ROLE_ID_MIN = 10000; // MUST be even
22
33
  uint32 public constant EXECUTION_DELAY = 0;
23
34
 
24
35
  // role specific state
25
- mapping(RoleId roleId => IAccess.RoleInfo info) internal _role;
36
+ mapping(RoleId roleId => IAccess.RoleInfo info) internal _roleInfo;
26
37
  mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
27
- mapping(ShortString name => RoleId roleId) internal _roleForName;
28
- RoleId [] internal _roles;
38
+ mapping(ShortString name => RoleId roleId) internal _roleIdForName;
39
+ RoleId [] internal _roleIds;
40
+ uint64 _idNext;
29
41
 
30
42
  // target specific state
31
- mapping(address target => IAccess.TargetInfo info) internal _target;
32
- mapping(ShortString name => address target) internal _targetForName;
43
+ mapping(address target => IAccess.TargetInfo info) internal _targetInfo;
44
+ mapping(ShortString name => address target) internal _targetAddressForName;
33
45
  address [] internal _targets;
34
46
 
35
- AccessManager internal _accessManager;
47
+ AccessManagerUpgradeableInitializeable internal _accessManager;
48
+ IRegistry internal _registry;
49
+
50
+ modifier restrictedToRoleAdmin(RoleId roleId) {
51
+ RoleId admin = getRoleAdmin(roleId);
52
+ (bool inRole, uint32 executionDelay) = _accessManager.hasRole(admin.toInt(), _msgSender());
53
+ assert(executionDelay == 0); // to be sure no delayed execution functionality is used
54
+ if (!inRole) {
55
+ revert IAccess.ErrorIAccessCallerIsNotRoleAdmin(_msgSender(), roleId);
56
+ }
57
+ _;
58
+ }
36
59
 
37
- function initialize(address initialAdmin) external initializer
60
+ // instance owner is granted upon instance nft minting in callback function
61
+ function initialize(address instanceAddress) external initializer
38
62
  {
39
- // if size of the contract gets too large, this can be externalized which will reduce the contract size considerably
40
- _accessManager = new AccessManager(address(this));
41
- // this service required admin rights to access manager to be able to grant/revoke roles
42
- _accessManager.grantRole(_accessManager.ADMIN_ROLE(), initialAdmin, 0);
63
+ IInstance instance = IInstance(instanceAddress);
64
+ IRegistry registry = instance.getRegistry();
65
+ address authority = instance.authority();
66
+
67
+ __AccessManaged_init(authority);
68
+
69
+ _accessManager = AccessManagerUpgradeableInitializeable(authority);
70
+ _registry = registry;
71
+ _idNext = CUSTOM_ROLE_ID_MIN;
72
+
73
+ _createRole(ADMIN_ROLE(), ADMIN_ROLE_NAME, IAccess.Type.Core);
74
+ _createRole(PUBLIC_ROLE(), PUBLIC_ROLE_NAME, IAccess.Type.Core);
75
+ _createRole(INSTANCE_ROLE(), INSTANCE_ROLE_NAME, IAccess.Type.Core);
76
+ _createRole(INSTANCE_OWNER_ROLE(), INSTANCE_OWNER_ROLE_NAME, IAccess.Type.Gif);// TODO should be of core type
43
77
 
44
- __AccessManaged_init(address(_accessManager));
78
+ // assume `this` is already a member of ADMIN_ROLE
79
+ EnumerableSet.add(_roleMembers[ADMIN_ROLE()], address(this));
45
80
 
46
- _createRole(RoleIdLib.toRoleId(_accessManager.ADMIN_ROLE()), ADMIN_ROLE_NAME, false, false);
47
- _createRole(RoleIdLib.toRoleId(_accessManager.PUBLIC_ROLE()), PUBLIC_ROLE_NAME, false, false);
81
+ // grant instance role to instance contract address
82
+ grantRole(INSTANCE_ROLE(), instanceAddress);
83
+ setRoleAdmin(INSTANCE_OWNER_ROLE(), INSTANCE_ROLE());
48
84
  }
49
85
 
50
86
  //--- Role ------------------------------------------------------//
51
- function createGifRole(RoleId roleId, string memory name) external restricted() {
52
- _createRole(roleId, name, false, true);
87
+ // ADMIN_ROLE
88
+ // assume all core roles are know at deployment time
89
+ // assume core roles are set and granted only during instance cloning
90
+ // assume core roles are never revoked -> core roles admin is never active after intialization
91
+ function createCoreRole(RoleId roleId, string memory name)
92
+ external
93
+ restricted()
94
+ {
95
+ _createRole(roleId, name, IAccess.Type.Core);
53
96
  }
54
97
 
55
- function createRole(RoleId roleId, string memory name) external restricted() {
56
- _createRole(roleId, name, true, true);
98
+ // ADMIN_ROLE
99
+ // assume gif roles can be revoked
100
+ // assume admin is INSTANCE_OWNER_ROLE or INSTANCE_ROLE
101
+ function createGifRole(RoleId roleId, string memory name, RoleId admin)
102
+ external
103
+ restricted()
104
+ {
105
+ _createRole(roleId, name, IAccess.Type.Gif);
106
+ setRoleAdmin(roleId, admin);
57
107
  }
58
108
 
59
- function setRoleLocked(RoleId roleId, bool locked) external restricted() {
60
- if (!roleExists(roleId)) {
61
- revert IAccess.ErrorIAccessSetLockedForNonexstentRole(roleId);
62
- }
109
+ // INSTANCE_OWNER_ROLE
110
+ // TODO specify how many owners role can have -> many roles MUST have exactly 1 member?
111
+ function createRole(string memory roleName, string memory adminName)
112
+ external
113
+ restricted()
114
+ returns(RoleId roleId, RoleId admin)
115
+ {
116
+ (roleId, admin) = _getNextCustomRoleId();
63
117
 
64
- _role[roleId].isLocked = locked;
65
- _role[roleId].updatedAt = TimestampLib.blockTimestamp();
66
- }
118
+ _createRole(roleId, roleName, IAccess.Type.Custom);
119
+ _createRole(admin, adminName, IAccess.Type.Custom);
67
120
 
68
- function roleExists(RoleId roleId) public view returns (bool exists) {
69
- return _role[roleId].createdAt.gtz();
121
+ // TODO works without this -> why?
122
+ setRoleAdmin(roleId, admin);
123
+ setRoleAdmin(admin, INSTANCE_OWNER_ROLE());
70
124
  }
71
125
 
72
- function grantRole(RoleId roleId, address member) external restricted() returns (bool granted) {
126
+ // ADMIN_ROLE
127
+ // assume used by instance service only during instance cloning
128
+ // assume used only by this.createRole(), this.createGifRole() afterwards
129
+ function setRoleAdmin(RoleId roleId, RoleId admin)
130
+ public
131
+ restricted()
132
+ {
73
133
  if (!roleExists(roleId)) {
74
- revert IAccess.ErrorIAccessGrantNonexstentRole(roleId);
134
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
75
135
  }
76
136
 
77
- if (_role[roleId].isLocked) {
78
- revert IAccess.ErrorIAccessRoleIdNotActive(roleId);
137
+ if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
138
+ revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Core);
79
139
  }
80
140
 
81
- if (!EnumerableSet.contains(_roleMembers[roleId], member)) {
82
- _accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
83
- EnumerableSet.add(_roleMembers[roleId], member);
84
- return true;
85
- }
141
+ if (!roleExists(admin)) {
142
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(admin);
143
+ }
86
144
 
87
- return false;
145
+ _roleInfo[roleId].admin = admin;
88
146
  }
89
147
 
90
- function revokeRole(RoleId roleId, address member) external restricted() returns (bool revoked) {
148
+ // TODO core role can be granted only to 1 member
149
+ function grantRole(RoleId roleId, address member)
150
+ public
151
+ restrictedToRoleAdmin(roleId)
152
+ returns (bool granted)
153
+ {
91
154
  if (!roleExists(roleId)) {
92
- revert IAccess.ErrorIAccessRevokeNonexstentRole(roleId);
155
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
93
156
  }
94
157
 
95
- if (EnumerableSet.contains(_roleMembers[roleId], member)) {
96
- _accessManager.revokeRole(roleId.toInt(), member);
97
- EnumerableSet.remove(_roleMembers[roleId], member);
98
- return true;
99
- }
100
-
101
- return false;
158
+ granted = EnumerableSet.add(_roleMembers[roleId], member);
159
+ if(granted) {
160
+ _accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
161
+ }
102
162
  }
103
163
 
104
- /// @dev not restricted function by intention
105
- /// the restriction to role members is already enforced by the call to the access manger
106
- function renounceRole(RoleId roleId) external returns (bool revoked) {
107
- address member = msg.sender;
164
+ function revokeRole(RoleId roleId, address member)
165
+ external
166
+ restrictedToRoleAdmin(roleId)
167
+ returns (bool)
168
+ {
169
+ return _revokeRole(roleId, member);
170
+ }
108
171
 
172
+ // INSTANCE_OWNER_ROLE
173
+ // IMPORTANT: unbounded function, revoke all or revert
174
+ // Instance owner role decides what to do in case of custom role admin bening revoked, e.g.:
175
+ // 1) revoke custom role from ALL members
176
+ // 2) revoke custom role admin from ALL members
177
+ // 3) 1) + 2)
178
+ // 4) revoke only 1 member of custom role admin
179
+ function revokeRoleAllMembers(RoleId roleId)
180
+ external
181
+ restrictedToRoleAdmin(roleId)
182
+ returns (bool revoked)
183
+ {
109
184
  if (!roleExists(roleId)) {
110
- revert IAccess.ErrorIAccessRenounceNonexstentRole(roleId);
185
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
111
186
  }
112
187
 
113
- if (EnumerableSet.contains(_roleMembers[roleId], member)) {
114
- // cannot use accessManger.renounce as it directly checks against msg.sender
115
- _accessManager.revokeRole(roleId.toInt(), member);
188
+ uint memberCount = EnumerableSet.length(_roleMembers[roleId]);
189
+ for(uint memberIdx = 0; memberIdx < memberCount; memberIdx++)
190
+ {
191
+ address member = EnumerableSet.at(_roleMembers[roleId], memberIdx);
116
192
  EnumerableSet.remove(_roleMembers[roleId], member);
117
- return true;
193
+ _accessManager.revokeRole(roleId.toInt(), member);
194
+ }
195
+ }
196
+
197
+ /// @dev not restricted function by intention
198
+ /// the restriction to role members is already enforced by the call to the access manager
199
+ function renounceRole(RoleId roleId)
200
+ external
201
+ returns (bool)
202
+ {
203
+ IAccess.Type rtype = _roleInfo[roleId].rtype;
204
+ if(rtype == IAccess.Type.Core || rtype == IAccess.Type.Gif) {
205
+ revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, rtype);
118
206
  }
119
207
 
120
- return false;
208
+ address member = msg.sender;
209
+ // cannot use accessManger.renounce as it directly checks against msg.sender
210
+ return _revokeRole(roleId, member);
121
211
  }
122
212
 
123
- function roles() external view returns (uint256 numberOfRoles) {
124
- return _roles.length;
213
+ function roleExists(RoleId roleId) public view returns (bool exists) {
214
+ return _roleInfo[roleId].createdAt.gtz();
215
+ }
216
+ // TODO returns ADMIN_ROLE id for non existent roleId
217
+ function getRoleAdmin(RoleId roleId) public view returns(RoleId admin) {
218
+ return _roleInfo[roleId].admin;
219
+ }
220
+
221
+ function getRoleInfo(RoleId roleId) external view returns (IAccess.RoleInfo memory info) {
222
+ return _roleInfo[roleId];
223
+ }
224
+
225
+ function roleMembers(RoleId roleId) public view returns (uint256 numberOfMembers) {
226
+ return EnumerableSet.length(_roleMembers[roleId]);
125
227
  }
126
228
 
127
229
  function getRoleId(uint256 idx) external view returns (RoleId roleId) {
128
- return _roles[idx];
230
+ return _roleIds[idx];
129
231
  }
130
232
 
233
+ // TODO returns ADMIN_ROLE id for non existent name
131
234
  function getRoleIdForName(string memory name) external view returns (RoleId roleId) {
132
- return _roleForName[ShortStrings.toShortString(name)];
235
+ return _roleIdForName[ShortStrings.toShortString(name)];
133
236
  }
134
237
 
135
- function getRole(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
136
- return _role[roleId];
238
+ function roleMember(RoleId roleId, uint256 idx) external view returns (address member) {
239
+ return EnumerableSet.at(_roleMembers[roleId], idx);
137
240
  }
138
241
 
139
242
  function hasRole(RoleId roleId, address account) external view returns (bool accountHasRole) {
140
243
  (accountHasRole, ) = _accessManager.hasRole(roleId.toInt(), account);
141
244
  }
142
245
 
143
- function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
144
- return EnumerableSet.length(_roleMembers[roleId]);
246
+ function roles() external view returns (uint256 numberOfRoles) {
247
+ return _roleIds.length;
145
248
  }
146
249
 
147
- function getRoleMember(RoleId roleId, uint256 idx) external view returns (address roleMember) {
148
- return EnumerableSet.at(_roleMembers[roleId], idx);
250
+ //--- Target ------------------------------------------------------//
251
+ // ADMIN_ROLE
252
+ // assume some core targets are registred (instance) while others are not (instance accesss manager, instance reader, bundle manager)
253
+ function createCoreTarget(address target, string memory name) external restricted() {
254
+ _createTarget(target, name, IAccess.Type.Core);
149
255
  }
256
+ // INSTANCE_SERVICE_ROLE
257
+ // TODO check for instance mismatch?
258
+ function createGifTarget(address target, string memory name) external restricted()
259
+ {
260
+ if(!_registry.isRegistered(target)) {
261
+ revert IAccess.ErrorIAccessTargetNotRegistered(target);
262
+ }
150
263
 
151
- //--- Target ------------------------------------------------------//
152
- function createGifTarget(address target, string memory name) external restricted() {
153
- _createTarget(target, name, false, true);
264
+ _createTarget(target, name, IAccess.Type.Gif);
265
+ }
266
+ // INSTANCE_OWNER_ROLE
267
+ // assume custom target.authority() is constant -> target MUST not be used with different instance access manager
268
+ // assume custom target can not be registered as component -> each service which is doing component registration MUST register a gif target
269
+ // assume custom target can not be registered as instance or service -> why?
270
+ // TODO check target associated with instance owner or instance or instance components or components helpers
271
+ function createTarget(address target, string memory name) external restricted()
272
+ {
273
+ _createTarget(target, name, IAccess.Type.Custom);
154
274
  }
155
275
 
156
- function createTarget(address target, string memory name) external restricted() {
157
- _createTarget(target, name, true, true);
276
+ // TODO instance owner locks component instead of revoking it access to the instance...
277
+ function setTargetLockedByService(address target, bool locked)
278
+ external
279
+ restricted // INSTANCE_SERVICE_ROLE
280
+ {
281
+ _setTargetLocked(target, locked);
158
282
  }
159
283
 
160
- function setTargetLocked(string memory targetName, bool locked) external restricted() {
161
- address target = _targetForName[ShortStrings.toShortString(targetName)];
162
-
163
- if (target == address(0)) {
164
- revert IAccess.ErrorIAccessSetLockedForNonexstentTarget(target);
284
+ function setTargetLockedByInstance(address target, bool locked)
285
+ external
286
+ restricted // INSTANCE_ROLE
287
+ {
288
+ _setTargetLocked(target, locked);
289
+ }
290
+
291
+
292
+ // allowed combinations of roles and targets:
293
+ //1) set core role for core target
294
+ //2) set gif role for gif target
295
+ //3) set custom role for gif target
296
+ //4) set custom role for custom target
297
+
298
+ // ADMIN_ROLE if used only during initialization, works with:
299
+ // any roles for any targets
300
+ // INSTANCE_SERVICE_ROLE if used not only during initilization, works with:
301
+ // core roles for core targets
302
+ // gif roles for gif targets
303
+ function setCoreTargetFunctionRole(
304
+ string memory targetName,
305
+ bytes4[] calldata selectors,
306
+ RoleId roleId
307
+ )
308
+ public
309
+ virtual
310
+ restricted()
311
+ {
312
+ ShortString nameShort = ShortStrings.toShortString(targetName);
313
+ address target = _targetAddressForName[nameShort];
314
+
315
+ // not custom target
316
+ if(_targetInfo[target].ttype == IAccess.Type.Custom) {
317
+ revert IAccess.ErrorIAccessTargetTypeInvalid(target, IAccess.Type.Custom);
165
318
  }
166
319
 
167
- _target[target].isLocked = locked;
168
- _accessManager.setTargetClosed(target, locked);
169
- }
320
+ // not custom role
321
+ if(_roleInfo[roleId].rtype == IAccess.Type.Custom) {
322
+ revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Custom);
323
+ }
170
324
 
171
- function targetExists(address target) public view returns (bool exists) {
172
- return _target[target].createdAt.gtz();
325
+ _setTargetFunctionRole(target, nameShort, selectors, roleId);
173
326
  }
174
327
 
175
- //--- internal view/pure functions --------------------------------------//
328
+ // INSTANCE_OWNER_ROLE
329
+ // gif role for gif target
330
+ // gif role for custom target
331
+ // custom role for gif target
332
+ // custom role for custom target
333
+ // TODO instance owner can mess with gif target (component) -> e.g. set custom role for function intendent to work with gif role
334
+ function setTargetFunctionRole(
335
+ string memory targetName,
336
+ bytes4[] calldata selectors,
337
+ RoleId roleId
338
+ )
339
+ public
340
+ virtual
341
+ restricted()
342
+ {
343
+ ShortString nameShort = ShortStrings.toShortString(targetName);
344
+ address target = _targetAddressForName[nameShort];
345
+
346
+ // not core target
347
+ if(_targetInfo[target].ttype == IAccess.Type.Core) {
348
+ revert IAccess.ErrorIAccessTargetTypeInvalid(target, IAccess.Type.Core);
349
+ }
176
350
 
177
- function _createRole(RoleId roleId, string memory name, bool isCustom, bool validateParameters) internal {
178
- if (validateParameters) {
179
- _validateRoleParameters(roleId, name, isCustom);
351
+ // not core role
352
+ if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
353
+ revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Core);
180
354
  }
181
355
 
182
- IAccess.RoleInfo memory role = IAccess.RoleInfo(
183
- ShortStrings.toShortString(name),
184
- isCustom,
185
- false, // role un-locked,
186
- TimestampLib.blockTimestamp(),
187
- TimestampLib.blockTimestamp());
356
+ _setTargetFunctionRole(target, nameShort, selectors, roleId);
357
+ }
188
358
 
189
- _role[roleId] = role;
190
- _roleForName[role.name] = roleId;
191
- _roles.push(roleId);
359
+ function getTargetAddress(string memory targetName) public view returns(address targetAddress) {
360
+ ShortString nameShort = ShortStrings.toShortString(targetName);
361
+ return _targetAddressForName[nameShort];
192
362
  }
193
363
 
194
- function _validateRoleParameters(
195
- RoleId roleId,
196
- string memory name,
197
- bool isCustom
198
- )
364
+ function isTargetLocked(address target) public view returns (bool locked) {
365
+ return _targetInfo[target].isLocked;
366
+ }
367
+
368
+ function targetExists(address target) public view returns (bool exists) {
369
+ return _targetInfo[target].createdAt.gtz();
370
+ }
371
+
372
+ function getTargetInfo(address target) public view returns (IAccess.TargetInfo memory) {
373
+ return _targetInfo[target];
374
+ }
375
+
376
+ //--- Role internal view/pure functions --------------------------------------//
377
+ function _createRole(RoleId roleId, string memory roleName, IAccess.Type rtype)
199
378
  internal
200
- view
201
- returns (IAccess.RoleInfo memory existingRole)
202
379
  {
203
- // check role id
204
- uint64 roleIdInt = RoleId.unwrap(roleId);
205
- if(roleIdInt == _accessManager.ADMIN_ROLE() || roleIdInt == _accessManager.PUBLIC_ROLE()) {
206
- revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
380
+ ShortString name = ShortStrings.toShortString(roleName);
381
+ _validateRole(roleId, name, rtype);
382
+
383
+ if(roleExists(roleId)) {
384
+ revert IAccess.ErrorIAccessRoleIdExists(roleId);
207
385
  }
208
386
 
209
- // prevent changing isCustom for existing roles
210
- existingRole = _role[roleId];
387
+ if (_roleIdForName[name].gtz()) {
388
+ revert IAccess.ErrorIAccessRoleNameExists(roleId, _roleIdForName[name], name);
389
+ }
390
+
391
+ _roleInfo[roleId] = IAccess.RoleInfo(
392
+ name,
393
+ rtype,
394
+ ADMIN_ROLE(),
395
+ TimestampLib.blockTimestamp(),
396
+ TimestampLib.blockTimestamp()
397
+ );
398
+ _roleIdForName[name] = roleId;
399
+ _roleIds.push(roleId);
400
+
401
+ emit LogRoleCreation(roleId, name, rtype);
402
+ }
211
403
 
212
- if (existingRole.createdAt.gtz() && isCustom != existingRole.isCustom) {
213
- revert IAccess.ErrorIAccessRoleIsCustomIsImmutable(roleId, isCustom, existingRole.isCustom);
404
+ function _validateRole(RoleId roleId, ShortString name, IAccess.Type rtype)
405
+ internal
406
+ view
407
+ {
408
+ uint roleIdInt = roleId.toInt();
409
+ if(rtype == IAccess.Type.Custom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
410
+ revert IAccess.ErrorIAccessRoleIdTooSmall(roleId);
214
411
  }
215
412
 
216
- if (isCustom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
217
- revert IAccess.ErrorIAccessRoleIdTooSmall(roleId);
218
- } else if (!isCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
219
- revert IAccess.ErrorIAccessRoleIdTooBig(roleId);
413
+ if(
414
+ rtype != IAccess.Type.Custom &&
415
+ roleIdInt >= CUSTOM_ROLE_ID_MIN &&
416
+ roleIdInt != PUBLIC_ROLE().toInt())
417
+ {
418
+ revert IAccess.ErrorIAccessRoleIdTooBig(roleId);
220
419
  }
221
420
 
222
421
  // role name checks
223
- ShortString nameShort = ShortStrings.toShortString(name);
224
- if (ShortStrings.byteLength(nameShort) == 0) {
422
+ if (ShortStrings.byteLength(name) == 0) {
225
423
  revert IAccess.ErrorIAccessRoleNameEmpty(roleId);
226
424
  }
425
+ }
426
+
427
+ function _revokeRole(RoleId roleId, address member)
428
+ internal
429
+ returns(bool revoked)
430
+ {
431
+ if (!roleExists(roleId)) {
432
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
433
+ }
227
434
 
228
- if (_roleForName[nameShort] != RoleIdLib.zero() && _roleForName[nameShort] != roleId) {
229
- revert IAccess.ErrorIAccessRoleNameNotUnique(_roleForName[nameShort], nameShort);
435
+ revoked = EnumerableSet.remove(_roleMembers[roleId], member);
436
+ if(revoked) {
437
+ _accessManager.revokeRole(roleId.toInt(), member);
230
438
  }
231
439
  }
232
440
 
233
- function _createTarget(address target, string memory name, bool isCustom, bool validateParameters) internal {
234
- if (validateParameters) {
235
- _validateTargetParameters(target, name, isCustom);
236
- }
441
+ function _getNextCustomRoleId()
442
+ internal
443
+ returns(RoleId roleId, RoleId admin)
444
+ {
445
+ uint64 roleIdInt = _idNext;
446
+ uint64 adminInt = roleIdInt + 1;
237
447
 
238
- if (_target[target].createdAt.gtz()) {
239
- revert IAccess.ErrorIAccessTargetAlreadyExists(target, _target[target].name);
448
+ _idNext = roleIdInt + 2;
449
+
450
+ roleId = RoleIdLib.toRoleId(roleIdInt);
451
+ admin = RoleIdLib.toRoleId(adminInt);
452
+ }
453
+
454
+ //--- Target internal view/pure functions --------------------------------------//
455
+ function _createTarget(address target, string memory targetName, IAccess.Type ttype)
456
+ internal
457
+ {
458
+ ShortString name = ShortStrings.toShortString(targetName);
459
+ _validateTarget(target, name, ttype);
460
+
461
+ if (_targetInfo[target].createdAt.gtz()) {
462
+ revert IAccess.ErrorIAccessTargetExists(target, _targetInfo[target].name);
240
463
  }
241
- if (_targetForName[ShortStrings.toShortString(name)] != address(0)) {
242
- revert IAccess.ErrorIAccessTargetNameExists(target, _targetForName[ShortStrings.toShortString(name)], ShortStrings.toShortString(name));
464
+
465
+ if (_targetAddressForName[name] != address(0)) {
466
+ revert IAccess.ErrorIAccessTargetNameExists(
467
+ target,
468
+ _targetAddressForName[name],
469
+ name);
243
470
  }
244
471
 
245
- IAccess.TargetInfo memory info = IAccess.TargetInfo(
246
- ShortStrings.toShortString(name),
247
- isCustom,
248
- _accessManager.isTargetClosed(target), // sync with state in access manager
472
+ bool isLocked = _accessManager.isTargetClosed(target);// sync with state in access manager
473
+ _targetInfo[target] = IAccess.TargetInfo(
474
+ name,
475
+ ttype,
476
+ isLocked,
249
477
  TimestampLib.blockTimestamp(),
250
- TimestampLib.blockTimestamp());
251
-
252
- _target[target] = info;
253
- _targetForName[info.name] = target;
478
+ TimestampLib.blockTimestamp()
479
+ );
480
+ _targetAddressForName[name] = target;
254
481
  _targets.push(target);
482
+
483
+ emit LogTargetCreation(target, name, ttype, isLocked);
255
484
  }
256
485
 
257
- function _validateTargetParameters(address target, string memory name, bool isCustom) internal view {
258
- // TODO: implement
486
+ function _validateTarget(address target, ShortString name, IAccess.Type ttype)
487
+ internal
488
+ view
489
+ {
490
+ address targetAuthority = AccessManagedUpgradeable(target).authority();
491
+ if(targetAuthority != authority()) {
492
+ revert IAccess.ErrorIAccessTargetAuthorityInvalid(target, targetAuthority);
493
+ }
494
+
495
+ if (ShortStrings.byteLength(name) == 0) {
496
+ revert IAccess.ErrorIAccessTargetNameEmpty(target);
497
+ }
259
498
  }
260
499
 
261
- function setTargetFunctionRole(
262
- address target,
263
- bytes4[] calldata selectors,
264
- uint64 roleId
265
- ) public virtual restricted() {
266
- _accessManager.setTargetFunctionRole(target, selectors, roleId);
500
+ // IMPORTANT: instance access manager MUST be of Core type -> otherwise can be locked forever
501
+ function _setTargetLocked(address target, bool locked) internal
502
+ {
503
+ IAccess.Type targetType = _targetInfo[target].ttype;
504
+ if(target == address(0) || targetType == IAccess.Type.NotInitialized) {
505
+ revert IAccess.ErrorIAccessTargetDoesNotExist(target);
506
+ }
507
+
508
+ if(targetType == IAccess.Type.Core) {
509
+ revert IAccess.ErrorIAccessTargetTypeInvalid(target, targetType);
510
+ }
511
+
512
+ _targetInfo[target].isLocked = locked;
513
+ _accessManager.setTargetClosed(target, locked);
267
514
  }
268
515
 
269
- function setTargetFunctionRole(
270
- string memory targetName,
516
+ function _setTargetFunctionRole(
517
+ address target,
518
+ ShortString name,
271
519
  bytes4[] calldata selectors,
272
520
  RoleId roleId
273
- ) public virtual restricted() {
274
- address target = _targetForName[ShortStrings.toShortString(targetName)];
275
- uint64 roleIdInt = RoleId.unwrap(roleId);
276
- _accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
277
- }
278
-
279
- function setTargetClosed(string memory targetName, bool closed) public restricted() {
280
- address target = _targetForName[ShortStrings.toShortString(targetName)];
521
+ )
522
+ internal
523
+ {
281
524
  if (target == address(0)) {
282
- revert IAccess.ErrorIAccessTargetAddressZero();
525
+ revert IAccess.ErrorIAccessTargetDoesNotExist(target);
283
526
  }
284
- _accessManager.setTargetClosed(target, closed);
285
- }
286
527
 
287
- function isTargetLocked(address target) public view returns (bool locked) {
288
- return _accessManager.isTargetClosed(target);
528
+ if (!roleExists(roleId)) {
529
+ revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
530
+ }
531
+
532
+ uint64 roleIdInt = RoleId.unwrap(roleId);
533
+ _accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
289
534
  }
290
535
 
291
536
  function canCall(
@@ -295,4 +540,4 @@ contract InstanceAccessManager is
295
540
  ) public view virtual returns (bool immediate, uint32 delay) {
296
541
  return _accessManager.canCall(caller, target, selector);
297
542
  }
298
- }
543
+ }