@etherisc/gif-next 0.0.2-f2df3e2-873 → 0.0.2-f347f00-614

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 (571) hide show
  1. package/README.md +2 -1
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +238 -167
  4. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  5. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1378 -0
  6. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  7. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +826 -0
  8. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  9. package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +117 -111
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +49 -312
  12. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +36 -105
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +225 -2171
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +177 -41
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +378 -2689
  20. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  21. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
  22. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
  23. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +228 -0
  24. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  25. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +643 -345
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +262 -182
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +122 -105
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3598 -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 +1 -54
  36. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  38. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +187 -0
  40. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  41. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
  42. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  43. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  44. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  45. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  46. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  47. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  48. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  49. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  50. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
  51. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  52. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
  53. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  54. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
  55. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  56. package/artifacts/contracts/{components/Product.sol/Product.json → oracle/Oracle.sol/Oracle.json} +255 -276
  57. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  58. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
  59. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  60. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
  61. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  62. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1134 -0
  63. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  64. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +754 -0
  65. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  66. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +65 -48
  67. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  68. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +193 -103
  69. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  70. package/artifacts/contracts/{instance/service → pool}/IPoolService.sol/IPoolService.json +290 -56
  71. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  72. package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +298 -109
  73. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  74. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1453 -0
  75. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  76. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +742 -0
  77. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  78. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +863 -0
  79. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  80. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  81. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  82. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1315 -0
  83. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  84. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +822 -0
  85. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  86. package/artifacts/contracts/{instance/service/IClaimService.sol/IClaimService.json → product/IApplicationService.sol/IApplicationService.json} +96 -186
  87. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  88. package/artifacts/contracts/{instance/service/IPolicyService.sol/IPolicyService.json → product/IClaimService.sol/IClaimService.json} +93 -258
  89. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  90. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +720 -0
  91. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  92. package/artifacts/contracts/{instance/service/IApplicationService.sol/IApplicationService.json → product/IPricingService.sol/IPricingService.json} +63 -141
  93. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  94. package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +283 -118
  95. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  96. package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +11 -61
  97. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  98. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1183 -0
  99. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  100. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +766 -0
  101. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  102. package/artifacts/contracts/product/PricingService.sol/PricingService.json +1012 -0
  103. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  104. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  105. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  106. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  107. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  108. package/artifacts/contracts/product/ProductService.sol/ProductService.json +708 -0
  109. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  110. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +702 -0
  111. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  112. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  113. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  114. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +179 -29
  115. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  116. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +310 -53
  117. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  118. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +124 -0
  119. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  120. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  121. package/artifacts/contracts/registry/Registry.sol/Registry.json +415 -43
  122. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  123. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1896 -0
  124. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  125. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +367 -73
  126. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  127. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +105 -54
  128. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  129. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +762 -103
  130. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  131. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +166 -0
  132. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  133. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +182 -0
  134. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  135. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -153
  136. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  137. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1554 -0
  138. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  139. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
  140. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  141. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1747 -0
  142. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  143. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1760 -0
  144. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  145. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1838 -0
  146. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  147. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1856 -0
  148. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  149. package/artifacts/contracts/{components → shared}/Component.sol/Component.json +139 -85
  150. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  151. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1511 -0
  152. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  153. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
  154. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  155. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +27 -95
  156. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  157. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
  158. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  159. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1184 -0
  160. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  161. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  162. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  163. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  164. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  165. package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +110 -84
  166. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  167. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
  168. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  169. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
  170. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  171. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -11
  172. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  173. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  174. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  175. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +3 -10
  176. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  177. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +87 -9
  178. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  179. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +3 -10
  180. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  181. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
  182. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  183. package/artifacts/contracts/shared/IService.sol/IService.json +17 -6
  184. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  185. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  186. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  187. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  188. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  189. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  190. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
  191. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  192. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  193. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  194. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  195. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  196. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -22
  197. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  198. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +98 -26
  199. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  200. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +70 -35
  201. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  202. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +23 -22
  203. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  204. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  205. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  206. package/artifacts/contracts/shared/Service.sol/Service.json +17 -6
  207. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  208. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  209. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  210. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  211. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  212. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  213. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  214. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  215. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1035 -0
  216. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  217. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
  218. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  219. package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
  220. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  221. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  222. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  223. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
  224. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  225. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1343 -0
  226. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  227. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +718 -0
  228. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  229. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -0
  230. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  231. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  232. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  233. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  234. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  235. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  236. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  237. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  238. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  239. package/artifacts/contracts/{types → type}/ClaimId.sol/ClaimIdLib.json +5 -5
  240. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  241. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  242. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  243. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  244. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  245. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  246. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  247. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  248. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  249. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  250. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  251. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +186 -0
  252. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  253. package/artifacts/contracts/{types → type}/PayoutId.sol/PayoutIdLib.json +5 -5
  254. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  255. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  256. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  257. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  258. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  259. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  260. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  261. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +266 -0
  262. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  263. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  264. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  265. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  266. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  267. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  268. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  269. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  270. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  271. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  272. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  273. package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +20 -7
  274. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  275. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  276. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  277. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  278. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  279. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  280. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  281. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  282. package/contracts/{components → distribution}/Distribution.sol +41 -64
  283. package/contracts/distribution/DistributionService.sol +297 -0
  284. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  285. package/contracts/{components → distribution}/IDistributionComponent.sol +11 -16
  286. package/contracts/{instance/service → distribution}/IDistributionService.sol +19 -37
  287. package/contracts/instance/BundleManager.sol +5 -5
  288. package/contracts/instance/IInstance.sol +51 -66
  289. package/contracts/instance/IInstanceService.sol +51 -22
  290. package/contracts/instance/Instance.sol +137 -184
  291. package/contracts/instance/InstanceAdmin.sol +331 -0
  292. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  293. package/contracts/instance/InstanceReader.sol +130 -55
  294. package/contracts/instance/InstanceService.sol +258 -297
  295. package/contracts/instance/InstanceServiceManager.sol +11 -21
  296. package/contracts/instance/InstanceStore.sol +269 -0
  297. package/contracts/instance/base/BalanceStore.sol +123 -0
  298. package/contracts/instance/base/Cloneable.sol +28 -0
  299. package/contracts/instance/base/ObjectCounter.sol +21 -0
  300. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +7 -9
  301. package/contracts/instance/module/IAccess.sol +4 -12
  302. package/contracts/instance/module/IBundle.sol +6 -9
  303. package/contracts/instance/module/IComponents.sol +21 -10
  304. package/contracts/instance/module/IDistribution.sol +7 -6
  305. package/contracts/instance/module/IPolicy.sol +22 -15
  306. package/contracts/instance/module/IRisk.sol +1 -1
  307. package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
  308. package/contracts/oracle/IOracle.sol +20 -0
  309. package/contracts/oracle/IOracleComponent.sol +32 -0
  310. package/contracts/oracle/IOracleService.sol +65 -0
  311. package/contracts/oracle/Oracle.sol +145 -0
  312. package/contracts/oracle/OracleService.sol +278 -0
  313. package/contracts/oracle/OracleServiceManager.sol +42 -0
  314. package/contracts/pool/BundleService.sol +296 -0
  315. package/contracts/pool/BundleServiceManager.sol +42 -0
  316. package/contracts/{instance/service → pool}/IBundleService.sol +33 -23
  317. package/contracts/{components → pool}/IPoolComponent.sol +16 -17
  318. package/contracts/{instance/service → pool}/IPoolService.sol +72 -21
  319. package/contracts/{components → pool}/Pool.sol +52 -55
  320. package/contracts/pool/PoolService.sol +452 -0
  321. package/contracts/pool/PoolServiceManager.sol +42 -0
  322. package/contracts/product/ApplicationService.sol +254 -0
  323. package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
  324. package/contracts/product/ClaimService.sol +442 -0
  325. package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
  326. package/contracts/{instance/service → product}/IApplicationService.sol +13 -29
  327. package/contracts/product/IClaimService.sol +99 -0
  328. package/contracts/product/IPolicyService.sol +78 -0
  329. package/contracts/product/IPricingService.sol +39 -0
  330. package/contracts/product/IProductComponent.sol +42 -0
  331. package/contracts/product/IProductService.sol +33 -0
  332. package/contracts/product/PolicyService.sol +475 -0
  333. package/contracts/product/PolicyServiceManager.sol +42 -0
  334. package/contracts/product/PricingService.sol +300 -0
  335. package/contracts/product/PricingServiceManager.sol +42 -0
  336. package/contracts/{components → product}/Product.sol +89 -83
  337. package/contracts/product/ProductService.sol +124 -0
  338. package/contracts/product/ProductServiceManager.sol +42 -0
  339. package/contracts/registry/ChainNft.sol +8 -1
  340. package/contracts/registry/IRegistry.sol +44 -21
  341. package/contracts/registry/IRegistryService.sol +37 -36
  342. package/contracts/registry/IServiceAuthorization.sol +35 -0
  343. package/contracts/registry/Registry.sol +192 -83
  344. package/contracts/registry/RegistryAdmin.sol +333 -0
  345. package/contracts/registry/RegistryService.sol +71 -87
  346. package/contracts/registry/RegistryServiceManager.sol +21 -30
  347. package/contracts/registry/ReleaseManager.sol +394 -197
  348. package/contracts/registry/ServiceAuthorization.sol +83 -0
  349. package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
  350. package/contracts/registry/TokenRegistry.sol +261 -62
  351. package/contracts/shared/AccessAdmin.sol +750 -0
  352. package/contracts/shared/AccessManagerCustom.sol +741 -0
  353. package/contracts/shared/AccessManagerExtended.sol +481 -0
  354. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  355. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  356. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  357. package/contracts/shared/Component.sol +281 -0
  358. package/contracts/shared/ComponentService.sol +617 -0
  359. package/contracts/shared/ComponentServiceManager.sol +35 -0
  360. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  361. package/contracts/shared/ERC165.sol +1 -1
  362. package/contracts/shared/IAccessAdmin.sol +162 -0
  363. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  364. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  365. package/contracts/{components → shared}/IComponent.sol +23 -29
  366. package/contracts/shared/IComponentService.sol +102 -0
  367. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  368. package/contracts/{instance/base → shared}/IKeyValueStore.sol +15 -11
  369. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
  370. package/contracts/shared/INftOwnable.sol +2 -2
  371. package/contracts/shared/IPolicyHolder.sol +29 -10
  372. package/contracts/shared/IRegistryLinked.sol +0 -1
  373. package/contracts/shared/IService.sol +11 -2
  374. package/contracts/shared/IVersionable.sol +1 -1
  375. package/contracts/shared/InitializableCustom.sol +177 -0
  376. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  377. package/contracts/shared/KeyValueStore.sol +127 -0
  378. package/contracts/{instance/base → shared}/Lifecycle.sol +18 -5
  379. package/contracts/shared/NftIdSetManager.sol +65 -0
  380. package/contracts/shared/NftOwnable.sol +3 -16
  381. package/contracts/shared/PolicyHolder.sol +40 -19
  382. package/contracts/shared/ProxyManager.sol +34 -4
  383. package/contracts/shared/Registerable.sol +13 -12
  384. package/contracts/shared/RegistryLinked.sol +0 -5
  385. package/contracts/shared/Service.sol +32 -21
  386. package/contracts/shared/TokenHandler.sol +27 -2
  387. package/contracts/shared/Versionable.sol +1 -1
  388. package/contracts/staking/IStaking.sol +168 -0
  389. package/contracts/staking/IStakingService.sol +153 -0
  390. package/contracts/staking/StakeManagerLib.sol +231 -0
  391. package/contracts/staking/Staking.sol +513 -0
  392. package/contracts/staking/StakingManager.sol +54 -0
  393. package/contracts/staking/StakingReader.sol +187 -0
  394. package/contracts/staking/StakingService.sol +411 -0
  395. package/contracts/staking/StakingServiceManager.sol +44 -0
  396. package/contracts/staking/StakingStore.sol +613 -0
  397. package/contracts/staking/TargetManagerLib.sol +207 -0
  398. package/contracts/{types → type}/AddressSet.sol +1 -1
  399. package/contracts/type/Amount.sol +128 -0
  400. package/contracts/{types → type}/Blocknumber.sol +20 -3
  401. package/contracts/{types → type}/Fee.sol +24 -22
  402. package/contracts/{types → type}/NftId.sol +14 -16
  403. package/contracts/{types → type}/NftIdSet.sol +2 -2
  404. package/contracts/type/ObjectType.sol +241 -0
  405. package/contracts/{types → type}/Referral.sol +1 -1
  406. package/contracts/type/RequestId.sol +75 -0
  407. package/contracts/{types → type}/RiskId.sol +1 -1
  408. package/contracts/type/RoleId.sol +201 -0
  409. package/contracts/{types → type}/Seconds.sol +27 -0
  410. package/contracts/type/Selector.sol +102 -0
  411. package/contracts/{types → type}/StateId.sol +27 -2
  412. package/contracts/type/String.sol +53 -0
  413. package/contracts/{types → type}/Timestamp.sol +6 -2
  414. package/contracts/{types → type}/Version.sol +1 -1
  415. package/package.json +3 -3
  416. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  417. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  418. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  419. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  420. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  421. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  422. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  423. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  424. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  425. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  426. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  427. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  428. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1330
  429. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  430. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -256
  431. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  432. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  433. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  434. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  435. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -532
  436. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  437. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  438. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  439. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  440. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  441. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  442. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -1060
  443. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  444. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -681
  445. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  446. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1266
  447. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  448. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -725
  449. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  450. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -1040
  451. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  452. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -685
  453. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  454. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1774
  455. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  456. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -793
  457. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  458. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  459. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  460. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  461. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  462. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  463. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  464. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  465. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1511
  466. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  467. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -741
  468. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  469. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -1237
  470. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  471. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -661
  472. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  473. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -840
  474. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  475. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -653
  476. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  477. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  478. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  479. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  480. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  481. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  482. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  483. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
  484. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  485. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  486. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  487. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -596
  488. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  489. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  490. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  491. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  492. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  493. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  494. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  495. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  496. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  497. package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +0 -4
  498. package/artifacts/contracts/types/Amount.sol/AmountLib.json +0 -185
  499. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  500. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  501. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  502. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  503. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  504. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  505. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  506. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -288
  507. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  508. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  509. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -166
  510. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  511. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  512. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  513. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  514. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  515. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  516. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  517. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -142
  518. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  519. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  520. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  521. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +0 -4
  522. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +0 -124
  523. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  524. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  525. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  526. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  527. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  528. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  529. package/contracts/components/Component.sol +0 -253
  530. package/contracts/components/IProductComponent.sol +0 -40
  531. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
  532. package/contracts/instance/Cloneable.sol +0 -51
  533. package/contracts/instance/InstanceAccessManager.sol +0 -527
  534. package/contracts/instance/base/ComponentService.sol +0 -121
  535. package/contracts/instance/base/KeyValueStore.sol +0 -180
  536. package/contracts/instance/module/ISetup.sol +0 -33
  537. package/contracts/instance/module/ITreasury.sol +0 -23
  538. package/contracts/instance/service/ApplicationService.sol +0 -355
  539. package/contracts/instance/service/BundleService.sol +0 -436
  540. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  541. package/contracts/instance/service/ClaimService.sol +0 -239
  542. package/contracts/instance/service/DistributionService.sol +0 -431
  543. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  544. package/contracts/instance/service/IClaimService.sol +0 -92
  545. package/contracts/instance/service/IPolicyService.sol +0 -137
  546. package/contracts/instance/service/IProductService.sol +0 -40
  547. package/contracts/instance/service/PolicyService.sol +0 -541
  548. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  549. package/contracts/instance/service/PoolService.sol +0 -303
  550. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  551. package/contracts/instance/service/ProductService.sol +0 -210
  552. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  553. package/contracts/registry/RegistryAccessManager.sol +0 -216
  554. package/contracts/shared/ContractDeployerLib.sol +0 -72
  555. package/contracts/test/TestFee.sol +0 -25
  556. package/contracts/test/TestRegisterable.sol +0 -18
  557. package/contracts/test/TestRoleId.sol +0 -14
  558. package/contracts/test/TestService.sol +0 -25
  559. package/contracts/test/TestVersion.sol +0 -44
  560. package/contracts/test/TestVersionable.sol +0 -17
  561. package/contracts/test/Usdc.sol +0 -26
  562. package/contracts/types/Amount.sol +0 -65
  563. package/contracts/types/ChainId.sol +0 -38
  564. package/contracts/types/NumberId.sol +0 -52
  565. package/contracts/types/ObjectType.sol +0 -157
  566. package/contracts/types/RoleId.sol +0 -97
  567. /package/contracts/{types → type}/ClaimId.sol +0 -0
  568. /package/contracts/{types → type}/DistributorType.sol +0 -0
  569. /package/contracts/{types → type}/Key32.sol +0 -0
  570. /package/contracts/{types → type}/PayoutId.sol +0 -0
  571. /package/contracts/{types → type}/UFixed.sol +0 -0
@@ -0,0 +1,750 @@
1
+ // SPDX-License-Identifier: UNLICENSED
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {AccessManager} from "@openzeppelin/contracts/access/manager/AccessManager.sol";
5
+ import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
6
+ import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
7
+
8
+ import {IAccessAdmin} from "./IAccessAdmin.sol";
9
+ import {RoleId, RoleIdLib} from "../type/RoleId.sol";
10
+ import {Selector, SelectorLib, SelectorSetLib} from "../type/Selector.sol";
11
+ import {Str, StrLib} from "../type/String.sol";
12
+ import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
13
+
14
+
15
+ /**
16
+ * @dev A generic access amin contract that implements role based access control based on OpenZeppelin's AccessManager contract.
17
+ * The contract provides read functions to query all available roles, targets and access rights.
18
+ * This contract works for both a constructor based deployment or a deployment based on cloning and initialization.
19
+ */
20
+ contract AccessAdmin is
21
+ AccessManagedUpgradeable,
22
+ IAccessAdmin
23
+ {
24
+ using EnumerableSet for EnumerableSet.AddressSet;
25
+
26
+ string public constant ADMIN_ROLE_NAME = "AdminRole";
27
+ string public constant PUBLIC_ROLE_NAME = "PublicRole";
28
+
29
+ uint64 public constant MANAGER_ROLE = type(uint64).min + 1;
30
+ string public constant MANAGER_ROLE_NAME = "ManagerRole";
31
+
32
+ /// @dev the OpenZeppelin access manager driving the access admin contract
33
+ AccessManager internal _authority;
34
+
35
+ /// @dev stores the deployer address and allows to create initializers
36
+ /// that are restricted to the deployer address.
37
+ address internal _deployer;
38
+
39
+ /// @dev required role for state changes to this contract
40
+ RoleId internal _managerRoleId;
41
+
42
+ /// @dev store role info per role id
43
+ mapping(RoleId roleId => RoleInfo info) internal _roleInfo;
44
+
45
+ /// @dev store role name info per role name
46
+ mapping(Str roleName => RoleNameInfo nameInfo) internal _roleForName;
47
+
48
+ /// @dev store array with all created roles
49
+ RoleId [] internal _roleIds;
50
+
51
+ /// @dev store set of current role members for given role
52
+ mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
53
+
54
+ /// @dev store target info per target address
55
+ mapping(address target => TargetInfo info) internal _targetInfo;
56
+
57
+ /// @dev store role name info per role name
58
+ mapping(Str targetName => address target) internal _targetForName;
59
+
60
+ /// @dev store array with all created targets
61
+ address [] internal _targets;
62
+
63
+ /// @dev store all managed functions per target
64
+ mapping(address target => SelectorSetLib.Set selectors) internal _targetFunctions;
65
+
66
+ /// @dev temporary dynamic function infos array
67
+ mapping(address target => mapping(Selector selector => Str functionName)) internal _functionName;
68
+
69
+ /// @dev temporary dynamic functions array
70
+ bytes4[] private _functions;
71
+
72
+ modifier onlyDeployer() {
73
+ // special case for cloned AccessAdmin contracts
74
+ // IMPORTANT cloning and _initializeAuthority needs to be done in a single transaction
75
+ if (_deployer == address(0)) {
76
+ _deployer = msg.sender;
77
+ }
78
+
79
+ if (msg.sender != _deployer) {
80
+ revert ErrorNotDeployer();
81
+ }
82
+ _;
83
+ }
84
+
85
+ modifier onlyRoleAdmin(RoleId roleId) {
86
+ if (!roleExists(roleId)) {
87
+ revert ErrorRoleUnknown(roleId);
88
+ }
89
+
90
+ if (!hasRole(msg.sender, _roleInfo[roleId].adminRoleId)) {
91
+ revert ErrorNotAdminOfRole(_roleInfo[roleId].adminRoleId);
92
+ }
93
+ _;
94
+ }
95
+
96
+ modifier onlyRoleMember(RoleId roleId) {
97
+ if (!hasRole(msg.sender, roleId)) {
98
+ revert ErrorNotRoleOwner(roleId);
99
+ }
100
+ _;
101
+ }
102
+
103
+ modifier onlyExistingRole(RoleId roleId) {
104
+ _checkRoleId(roleId);
105
+ _;
106
+ }
107
+
108
+ modifier onlyExistingTarget(address target) {
109
+ _checkTarget(target);
110
+ _;
111
+ }
112
+
113
+ constructor() {
114
+ _deployer = msg.sender;
115
+ _authority = new AccessManager(address(this));
116
+
117
+ _setAuthority(address(_authority));
118
+ _createInitialRoleSetup();
119
+
120
+ _disableInitializers();
121
+ }
122
+
123
+ //--- role management functions -----------------------------------------//
124
+
125
+ function createRole(
126
+ RoleId roleId,
127
+ RoleId adminRoleId,
128
+ string memory name,
129
+ uint256 maxMemberCount,
130
+ bool memberRemovalDisabled
131
+ )
132
+ external
133
+ restricted()
134
+ {
135
+ _createRole(roleId, adminRoleId, name, maxMemberCount, memberRemovalDisabled);
136
+ }
137
+
138
+ function setRoleDisabled(
139
+ RoleId roleId,
140
+ bool disabled
141
+ )
142
+ external
143
+ restricted()
144
+ {
145
+ _setRoleDisabled(roleId, disabled);
146
+ }
147
+
148
+ function grantRole(
149
+ address account,
150
+ RoleId roleId
151
+ )
152
+ external
153
+ onlyRoleAdmin(roleId)
154
+ restricted()
155
+ {
156
+ _grantRoleToAccount(roleId, account);
157
+ }
158
+
159
+ function revokeRole(
160
+ address account,
161
+ RoleId roleId
162
+ )
163
+ external
164
+ onlyRoleAdmin(roleId)
165
+ restricted()
166
+ {
167
+ _revokeRoleFromAccount(roleId, account);
168
+ }
169
+
170
+ function renounceRole(
171
+ RoleId roleId
172
+ )
173
+ external
174
+ onlyRoleMember(roleId)
175
+ restricted()
176
+ {
177
+ _revokeRoleFromAccount(roleId, msg.sender);
178
+ }
179
+
180
+ //--- target management functions ---------------------------------------//
181
+
182
+ function createTarget(
183
+ address target,
184
+ string memory name
185
+ )
186
+ external
187
+ restricted()
188
+ {
189
+ _createTarget(target, name);
190
+ }
191
+
192
+ function setTargetLocked(
193
+ address target,
194
+ bool locked
195
+ )
196
+ external
197
+ onlyExistingTarget(target)
198
+ restricted()
199
+ {
200
+ _authority.setTargetClosed(target, locked);
201
+
202
+ // implizit logging: rely on OpenZeppelin log TargetClosed
203
+ }
204
+
205
+ function authorizeFunctions(
206
+ address target,
207
+ RoleId roleId,
208
+ Function[] memory functions
209
+ )
210
+ external
211
+ onlyExistingTarget(target)
212
+ onlyExistingRole(roleId)
213
+ restricted()
214
+ {
215
+ _authorizeTargetFunctions(target, roleId, functions);
216
+ }
217
+
218
+ function unauthorizeFunctions(
219
+ address target,
220
+ Function[] memory functions
221
+ )
222
+ external
223
+ restricted()
224
+ {
225
+ _unauthorizeTargetFunctions(target, functions);
226
+ }
227
+
228
+
229
+ function authorizedFunctions(address target) external view returns (uint256 numberOfFunctions) {
230
+ return SelectorSetLib.size(_targetFunctions[target]);
231
+ }
232
+
233
+ function getAuthorizedFunction(
234
+ address target,
235
+ uint256 idx
236
+ )
237
+ external
238
+ view
239
+ returns (
240
+ Function memory func,
241
+ RoleId roleId
242
+ )
243
+ {
244
+ Selector selector = SelectorSetLib.at(_targetFunctions[target], idx);
245
+
246
+ func = Function({
247
+ selector: selector,
248
+ name: _functionName[target][selector]});
249
+
250
+ roleId = RoleIdLib.toRoleId(
251
+ _authority.getTargetFunctionRole(
252
+ target,
253
+ selector.toBytes4()));
254
+ }
255
+
256
+ //--- view functions ----------------------------------------------------//
257
+
258
+ function roles() external view returns (uint256 numberOfRoles) {
259
+ return _roleIds.length;
260
+ }
261
+
262
+ function getRoleId(uint256 idx) external view returns (RoleId roleId) {
263
+ return _roleIds[idx];
264
+ }
265
+
266
+ function getAdminRole() public view returns (RoleId roleId) {
267
+ return RoleId.wrap(_authority.ADMIN_ROLE());
268
+ }
269
+
270
+ function getPublicRole() public view returns (RoleId roleId) {
271
+ return RoleId.wrap(_authority.PUBLIC_ROLE());
272
+ }
273
+
274
+ function getManagerRole() public view returns (RoleId roleId) {
275
+ return _managerRoleId;
276
+ }
277
+
278
+ function roleExists(RoleId roleId) public view returns (bool exists) {
279
+ return _roleInfo[roleId].exists;
280
+ }
281
+
282
+ function isRoleDisabled(RoleId roleId) public view returns (bool isActive) {
283
+ return _roleInfo[roleId].disabledAt <= TimestampLib.blockTimestamp();
284
+ }
285
+
286
+ function getRoleInfo(RoleId roleId) external view returns (RoleInfo memory) {
287
+ return _roleInfo[roleId];
288
+ }
289
+
290
+ function getRoleForName(Str name) external view returns (RoleNameInfo memory) {
291
+ return _roleForName[name];
292
+ }
293
+
294
+ function hasRole(address account, RoleId roleId) public view returns (bool) {
295
+ (bool isMember, ) = _authority.hasRole(
296
+ RoleId.unwrap(roleId),
297
+ account);
298
+ return isMember;
299
+ }
300
+
301
+ function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
302
+ return _roleMembers[roleId].length();
303
+ }
304
+
305
+ function getRoleMember(RoleId roleId, uint256 idx) external view returns (address account) {
306
+ return _roleMembers[roleId].at(idx);
307
+ }
308
+
309
+ function targetExists(address target) public view returns (bool exists) {
310
+ return _targetInfo[target].createdAt.gtz();
311
+ }
312
+
313
+ function isTargetLocked(address target) public view returns (bool locked) {
314
+ return _authority.isTargetClosed(target);
315
+ }
316
+
317
+ function targets() external view returns (uint256 numberOfTargets) {
318
+ return _targets.length;
319
+ }
320
+
321
+ function getTargetAddress(uint256 idx) external view returns (address target) {
322
+ return _targets[idx];
323
+ }
324
+
325
+ function getTargetInfo(address target) external view returns (TargetInfo memory targetInfo) {
326
+ return _targetInfo[target];
327
+ }
328
+
329
+ function getTargetForName(Str name) external view returns (address target) {
330
+ return _targetForName[name];
331
+ }
332
+
333
+ function isAccessManaged(address target) public view returns (bool) {
334
+ if (!_isContract(target)) {
335
+ return false;
336
+ }
337
+
338
+ (bool success, ) = target.staticcall(
339
+ abi.encodeWithSelector(
340
+ AccessManagedUpgradeable.authority.selector));
341
+
342
+ return success;
343
+ }
344
+
345
+ function canCall(address caller, address target, Selector selector) external view returns (bool can) {
346
+ (can, ) = _authority.canCall(caller, target, selector.toBytes4());
347
+ }
348
+
349
+ function deployer() public view returns (address) {
350
+ return _deployer;
351
+ }
352
+
353
+ function toFunction(bytes4 selector, string memory name) public pure returns (Function memory) {
354
+ return Function({
355
+ selector: SelectorLib.toSelector(selector),
356
+ name: StrLib.toStr(name)});
357
+ }
358
+
359
+ //--- internal/private functions -------------------------------------------------//
360
+
361
+ function _authorizeTargetFunctions(
362
+ address target,
363
+ RoleId roleId,
364
+ Function[] memory functions
365
+ )
366
+ internal
367
+ {
368
+ if (roleId == getAdminRole()) {
369
+ revert ErrorAuthorizeForAdminRoleInvalid(target);
370
+ }
371
+
372
+ bool addFunctions = true;
373
+ bytes4[] memory functionSelectors = _processFunctionSelectors(target, functions, addFunctions);
374
+
375
+ // apply authz via access manager
376
+ _grantRoleAccessToFunctions(target, roleId, functionSelectors);
377
+ }
378
+
379
+ function _unauthorizeTargetFunctions(
380
+ address target,
381
+ Function[] memory functions
382
+ )
383
+ internal
384
+ {
385
+ bool addFunctions = false;
386
+ bytes4[] memory functionSelectors = _processFunctionSelectors(target, functions, addFunctions);
387
+ _grantRoleAccessToFunctions(target, getAdminRole(), functionSelectors);
388
+ }
389
+
390
+ function _processFunctionSelectors(
391
+ address target,
392
+ Function[] memory functions,
393
+ bool addFunctions
394
+ )
395
+ internal
396
+ returns (
397
+ bytes4[] memory functionSelectors
398
+ )
399
+ {
400
+ uint256 n = functions.length;
401
+ functionSelectors = new bytes4[](n);
402
+ Function memory func;
403
+ Selector selector;
404
+
405
+ for (uint256 i = 0; i < n; i++) {
406
+ func = functions[i];
407
+ selector = func.selector;
408
+
409
+ // add function selector to target selector set if not in set
410
+ if (addFunctions) { SelectorSetLib.add(_targetFunctions[target], selector); }
411
+ else { SelectorSetLib.remove(_targetFunctions[target], selector); }
412
+
413
+ // set function name
414
+ _functionName[target][selector] = func.name;
415
+
416
+ // add bytes4 selector to function selector array
417
+ functionSelectors[i] = selector.toBytes4();
418
+ }
419
+ }
420
+
421
+ function _initializeAuthority(
422
+ address authorityAddress
423
+ )
424
+ internal
425
+ virtual
426
+ onlyInitializing()
427
+ onlyDeployer()
428
+ {
429
+ if (authority() != address(0)) {
430
+ revert ErrorAuthorityAlreadySet();
431
+ }
432
+
433
+ _authority = AccessManager(authorityAddress);
434
+
435
+ if(!hasRole(address(this), RoleId.wrap(_authority.ADMIN_ROLE()))) {
436
+ revert ErrorAdminRoleMissing();
437
+ }
438
+
439
+ __AccessManaged_init(address(_authority));
440
+ }
441
+
442
+
443
+ function _initializeRoleSetup()
444
+ internal
445
+ virtual
446
+ onlyInitializing()
447
+ {
448
+ _createInitialRoleSetup();
449
+ }
450
+
451
+
452
+ function _createInitialRoleSetup()
453
+ internal
454
+ {
455
+ RoleId adminRoleId = RoleIdLib.toRoleId(_authority.ADMIN_ROLE());
456
+ Function[] memory functions;
457
+
458
+ // setup admin role
459
+ _createRoleUnchecked(
460
+ adminRoleId,
461
+ adminRoleId,
462
+ StrLib.toStr(ADMIN_ROLE_NAME),
463
+ 1,
464
+ true);
465
+
466
+ // add this contract as admin role member
467
+ _roleMembers[adminRoleId].add(address(this));
468
+
469
+ // setup public role
470
+ _createRoleUnchecked(
471
+ RoleIdLib.toRoleId(_authority.PUBLIC_ROLE()),
472
+ adminRoleId,
473
+ StrLib.toStr(PUBLIC_ROLE_NAME),
474
+ type(uint256).max,
475
+ true);
476
+
477
+ // setup manager role
478
+ _managerRoleId = RoleIdLib.toRoleId(MANAGER_ROLE);
479
+ _createRole(
480
+ _managerRoleId,
481
+ adminRoleId,
482
+ MANAGER_ROLE_NAME,
483
+ 3, // TODO think about max member count
484
+ false);
485
+
486
+ // grant public role access to grant and revoke, renounce
487
+ functions = new Function[](3);
488
+ functions[0] = toFunction(IAccessAdmin.grantRole.selector, "grantRole");
489
+ functions[1] = toFunction(IAccessAdmin.revokeRole.selector, "revokeRole");
490
+ functions[2] = toFunction(IAccessAdmin.renounceRole.selector, "renounceRole");
491
+ _authorizeTargetFunctions(address(this), getPublicRole(), functions);
492
+
493
+ // grant manager role access to the specified functions
494
+ functions = new Function[](6);
495
+ functions[0] = toFunction(IAccessAdmin.createRole.selector, "createRole");
496
+ functions[1] = toFunction(IAccessAdmin.setRoleDisabled.selector, "setRoleDisabled");
497
+ functions[2] = toFunction(IAccessAdmin.createTarget.selector, "createTarget");
498
+ functions[3] = toFunction(IAccessAdmin.setTargetLocked.selector, "setTargetLocked");
499
+ functions[4] = toFunction(IAccessAdmin.authorizeFunctions.selector, "authorizeFunctions");
500
+ functions[5] = toFunction(IAccessAdmin.unauthorizeFunctions.selector, "unauthorizeFunctions");
501
+ _authorizeTargetFunctions(address(this), getManagerRole(), functions);
502
+ }
503
+
504
+ /// @dev check if target exists and reverts if it doesn't
505
+ function _checkTarget(address target)
506
+ internal
507
+ {
508
+ if (_targetInfo[target].createdAt.eqz()) {
509
+ revert ErrorTargetUnknown(target);
510
+ }
511
+ }
512
+
513
+ /// @dev grant the specified role access to all functions in the provided selector list
514
+ function _grantRoleAccessToFunctions(
515
+ address target,
516
+ RoleId roleId,
517
+ bytes4[] memory functionSelectors
518
+ )
519
+ internal
520
+ {
521
+ _authority.setTargetFunctionRole(
522
+ target,
523
+ functionSelectors,
524
+ RoleId.unwrap(roleId));
525
+
526
+ // implizit logging: rely on OpenZeppelin log TargetFunctionRoleUpdated
527
+ }
528
+
529
+ /// @dev grant the specified role to the provided account
530
+ function _grantRoleToAccount(RoleId roleId, address account)
531
+ internal
532
+ {
533
+ _checkRoleId(roleId);
534
+ _checkRoleIsActive(roleId);
535
+
536
+ // check max role members will not be exceeded
537
+ if (_roleMembers[roleId].length() >= _roleInfo[roleId].maxMemberCount) {
538
+ revert ErrorRoleMembersLimitReached(roleId, _roleInfo[roleId].maxMemberCount);
539
+ }
540
+
541
+ _roleMembers[roleId].add(account);
542
+ _authority.grantRole(
543
+ RoleId.unwrap(roleId),
544
+ account,
545
+ 0);
546
+
547
+ // indirect logging: rely on OpenZeppelin log RoleGranted
548
+ }
549
+
550
+ /// @dev revoke the specified role from the provided account
551
+ function _revokeRoleFromAccount(RoleId roleId, address account)
552
+ internal
553
+ {
554
+ _checkRoleId(roleId);
555
+
556
+ // check role removal is permitted
557
+ if (_roleInfo[roleId].memberRemovalDisabled) {
558
+ revert ErrorRoleRemovalDisabled(roleId);
559
+ }
560
+
561
+ _roleMembers[roleId].remove(account);
562
+ _authority.revokeRole(
563
+ RoleId.unwrap(roleId),
564
+ account);
565
+
566
+ // indirect logging: rely on OpenZeppelin log RoleGranted
567
+ }
568
+
569
+
570
+ function _checkRoleId(RoleId roleId)
571
+ internal
572
+ {
573
+ if (!_roleInfo[roleId].exists) {
574
+ revert ErrorRoleUnknown(roleId);
575
+ }
576
+
577
+ uint64 roleIdInt = RoleId.unwrap(roleId);
578
+ if (roleIdInt == _authority.ADMIN_ROLE()
579
+ || roleIdInt == _authority.PUBLIC_ROLE())
580
+ {
581
+ revert ErrorRoleIsLocked(roleId);
582
+ }
583
+ }
584
+
585
+
586
+ function _checkRoleIsActive(RoleId roleId)
587
+ internal
588
+ {
589
+ if (isRoleDisabled(roleId)) {
590
+ revert ErrorRoleIsDisabled(roleId);
591
+ }
592
+ }
593
+
594
+
595
+ function _createRole(
596
+ RoleId roleId,
597
+ RoleId adminRoleId,
598
+ string memory roleName,
599
+ uint256 maxMemberCount,
600
+ bool memberRemovalDisabled
601
+ )
602
+ internal
603
+ {
604
+ // check role does not yet exist
605
+ if(roleExists(roleId)) {
606
+ revert ErrorRoleAlreadyCreated(
607
+ roleId,
608
+ _roleInfo[roleId].name.toString());
609
+ }
610
+
611
+ // check admin role exists
612
+ if(!roleExists(adminRoleId)) {
613
+ revert ErrorRoleAdminNotExisting(adminRoleId);
614
+ }
615
+
616
+ // check role name is not empty
617
+ Str name = StrLib.toStr(roleName);
618
+ if(name.length() == 0) {
619
+ revert ErrorRoleNameEmpty(roleId);
620
+ }
621
+
622
+ // check role name is not used for another role
623
+ if(_roleForName[name].exists) {
624
+ revert ErrorRoleNameAlreadyExists(
625
+ roleId,
626
+ roleName,
627
+ _roleForName[name].roleId);
628
+ }
629
+
630
+ _createRoleUnchecked(
631
+ roleId, adminRoleId,
632
+ name,
633
+ maxMemberCount,
634
+ memberRemovalDisabled);
635
+ }
636
+
637
+
638
+ function _setRoleDisabled(
639
+ RoleId roleId,
640
+ bool disabled
641
+ )
642
+ internal
643
+ {
644
+
645
+ _checkRoleId(roleId);
646
+ Timestamp disabledAtOld = _roleInfo[roleId].disabledAt;
647
+
648
+ if (disabled) {
649
+ _roleInfo[roleId].disabledAt = TimestampLib.blockTimestamp();
650
+ } else {
651
+ _roleInfo[roleId].disabledAt = TimestampLib.max();
652
+ }
653
+
654
+ emit LogRoleDisabled(roleId, disabled, disabledAtOld);
655
+ }
656
+
657
+
658
+ function _createRoleUnchecked(
659
+ RoleId roleId,
660
+ RoleId adminRoleId,
661
+ Str name,
662
+ uint256 maxMemberCount,
663
+ bool memberRemovalDisabled
664
+ )
665
+ private
666
+ {
667
+ // create role info
668
+ _roleInfo[roleId] = RoleInfo({
669
+ adminRoleId: adminRoleId,
670
+ name: name,
671
+ maxMemberCount: maxMemberCount,
672
+ memberRemovalDisabled: memberRemovalDisabled,
673
+ disabledAt: TimestampLib.max(),
674
+ exists: true});
675
+
676
+ // create role name info
677
+ _roleForName[name] = RoleNameInfo({
678
+ roleId: roleId,
679
+ exists: true});
680
+
681
+ // add role to list of roles
682
+ _roleIds.push(roleId);
683
+
684
+ emit LogRoleCreated(roleId, adminRoleId, name.toString());
685
+ }
686
+
687
+
688
+ function _createTarget(address target, string memory targetName)
689
+ internal
690
+ {
691
+ // check target does not yet exist
692
+ if(targetExists(target)) {
693
+ revert ErrorTargetAlreadyCreated(
694
+ target,
695
+ _targetInfo[target].name.toString());
696
+ }
697
+
698
+ // check target name is not empty
699
+ Str name = StrLib.toStr(targetName);
700
+ if(name.length() == 0) {
701
+ revert ErrorTargetNameEmpty(target);
702
+ }
703
+
704
+ // check target name is not used for another role
705
+ if( _targetForName[name] != address(0)) {
706
+ revert ErrorTargetNameAlreadyExists(
707
+ target,
708
+ targetName,
709
+ _targetForName[name]);
710
+ }
711
+
712
+ // check target is an access managed contract
713
+ if (!isAccessManaged(target)) {
714
+ revert ErrorTargetNotAccessManaged(target);
715
+ }
716
+
717
+ // check target shares authority with this contract
718
+ address targetAuthority = AccessManagedUpgradeable(target).authority();
719
+ if (targetAuthority != authority()) {
720
+ revert ErrorTargetAuthorityMismatch(authority(), targetAuthority);
721
+ }
722
+
723
+ // create target info
724
+ _targetInfo[target] = TargetInfo({
725
+ name: name,
726
+ createdAt: TimestampLib.blockTimestamp()
727
+ });
728
+
729
+ // create name to target mapping
730
+ _targetForName[name] = target;
731
+
732
+ // add role to list of roles
733
+ _targets.push(target);
734
+
735
+ emit LogTargetCreated(target, targetName);
736
+ }
737
+
738
+ function _isContract(address target)
739
+ internal
740
+ view
741
+ returns (bool)
742
+ {
743
+ uint256 size;
744
+ assembly {
745
+ size := extcodesize(target)
746
+ }
747
+ return size > 0;
748
+ }
749
+
750
+ }