@etherisc/gif-next 0.0.2-f30e0eb-805 → 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 (573) hide show
  1. package/README.md +8 -84
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +254 -157
  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 +202 -96
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +126 -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 +279 -1961
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +257 -55
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +431 -2735
  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 +762 -340
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +358 -171
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +128 -71
  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 +10 -118
  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/{components/IProductComponent.sol/IProductComponent.json → oracle/IOracleComponent.sol/IOracleComponent.json} +221 -192
  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 -266
  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 +218 -145
  67. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  68. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +288 -88
  69. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  70. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1078 -0
  71. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  72. package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +298 -89
  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/IPolicyService.sol/IPolicyService.json → product/IApplicationService.sol/IApplicationService.json} +174 -202
  87. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  88. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +772 -0
  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} +146 -153
  93. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  94. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
  95. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  96. package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +80 -64
  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 -77
  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 +372 -97
  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 +769 -98
  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 +144 -80
  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} +100 -113
  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 +180 -54
  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 +96 -19
  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 +103 -21
  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/type/ClaimId.sol/ClaimIdLib.json +179 -0
  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/type/PayoutId.sol/PayoutIdLib.json +209 -0
  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 +33 -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 +47 -66
  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 +20 -37
  287. package/contracts/instance/BundleManager.sol +8 -9
  288. package/contracts/instance/IInstance.sol +55 -66
  289. package/contracts/instance/IInstanceService.sol +50 -25
  290. package/contracts/instance/Instance.sol +160 -224
  291. package/contracts/instance/InstanceAdmin.sol +331 -0
  292. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  293. package/contracts/instance/InstanceReader.sol +157 -55
  294. package/contracts/instance/InstanceService.sol +259 -315
  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 +5 -13
  302. package/contracts/instance/module/IBundle.sol +8 -9
  303. package/contracts/instance/module/IComponents.sol +22 -5
  304. package/contracts/instance/module/IDistribution.sol +7 -6
  305. package/contracts/instance/module/IPolicy.sol +28 -16
  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/pool/IBundleService.sol +106 -0
  317. package/contracts/{components → pool}/IPoolComponent.sol +17 -18
  318. package/contracts/pool/IPoolService.sol +150 -0
  319. package/contracts/{components → pool}/Pool.sol +57 -57
  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 +15 -35
  327. package/contracts/product/IClaimService.sol +99 -0
  328. package/contracts/{instance/service → product}/IPolicyService.sol +37 -31
  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 +191 -107
  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 +39 -37
  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 +73 -90
  346. package/contracts/registry/RegistryServiceManager.sol +21 -30
  347. package/contracts/registry/ReleaseManager.sol +394 -195
  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 -27
  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 +14 -7
  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 +26 -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 +47 -22
  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}/ClaimId.sol +25 -2
  402. package/contracts/{types → type}/Fee.sol +33 -24
  403. package/contracts/{types → type}/NftId.sol +14 -16
  404. package/contracts/{types → type}/NftIdSet.sol +2 -2
  405. package/contracts/type/ObjectType.sol +241 -0
  406. package/contracts/{types → type}/PayoutId.sol +33 -5
  407. package/contracts/{types → type}/Referral.sol +1 -1
  408. package/contracts/type/RequestId.sol +75 -0
  409. package/contracts/{types → type}/RiskId.sol +1 -1
  410. package/contracts/type/RoleId.sol +201 -0
  411. package/contracts/{types → type}/Seconds.sol +27 -0
  412. package/contracts/type/Selector.sol +102 -0
  413. package/contracts/{types → type}/StateId.sol +33 -4
  414. package/contracts/type/String.sol +53 -0
  415. package/contracts/{types → type}/Timestamp.sol +10 -1
  416. package/contracts/{types → type}/Version.sol +1 -1
  417. package/package.json +3 -3
  418. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  419. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  420. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  421. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  422. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  423. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  424. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  425. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  426. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  427. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  428. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  429. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  430. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1311
  431. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  432. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -256
  433. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  434. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  435. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  436. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  437. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -532
  438. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  439. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  440. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  441. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  442. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  443. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  444. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -968
  445. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  446. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -665
  447. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  448. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1093
  449. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  450. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -661
  451. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  452. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -754
  453. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  454. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -637
  455. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  456. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1732
  457. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  458. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -805
  459. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  460. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  461. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  462. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +0 -409
  463. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  464. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  465. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  466. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -428
  467. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  468. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  469. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1021
  470. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  471. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -689
  472. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  473. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -824
  474. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  475. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -657
  476. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  477. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -777
  478. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  479. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -649
  480. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  481. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  482. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  483. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  484. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  485. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  486. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  487. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
  488. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  489. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  490. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  491. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -521
  492. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  493. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  494. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  495. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  496. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  497. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  498. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  499. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  500. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  501. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  502. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  503. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  504. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  505. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  506. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
  507. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  508. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  509. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  510. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  511. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  512. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -166
  513. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  514. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  515. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  516. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  517. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  518. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  519. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
  520. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  521. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -142
  522. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  523. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  524. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  525. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +0 -4
  526. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +0 -124
  527. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  528. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  529. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  530. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  531. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  532. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  533. package/contracts/components/Component.sol +0 -251
  534. package/contracts/components/IProductComponent.sol +0 -40
  535. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
  536. package/contracts/instance/Cloneable.sol +0 -51
  537. package/contracts/instance/InstanceAccessManager.sol +0 -522
  538. package/contracts/instance/base/ComponentService.sol +0 -134
  539. package/contracts/instance/base/KeyValueStore.sol +0 -175
  540. package/contracts/instance/module/ISetup.sol +0 -33
  541. package/contracts/instance/module/ITreasury.sol +0 -23
  542. package/contracts/instance/service/ApplicationService.sol +0 -350
  543. package/contracts/instance/service/BundleService.sol +0 -336
  544. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  545. package/contracts/instance/service/ClaimService.sol +0 -151
  546. package/contracts/instance/service/DistributionService.sol +0 -467
  547. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  548. package/contracts/instance/service/IBundleService.sol +0 -62
  549. package/contracts/instance/service/IClaimService.sol +0 -61
  550. package/contracts/instance/service/IPoolService.sol +0 -35
  551. package/contracts/instance/service/IProductService.sol +0 -40
  552. package/contracts/instance/service/PolicyService.sol +0 -403
  553. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  554. package/contracts/instance/service/PoolService.sol +0 -220
  555. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  556. package/contracts/instance/service/ProductService.sol +0 -241
  557. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  558. package/contracts/registry/RegistryAccessManager.sol +0 -216
  559. package/contracts/shared/ContractDeployerLib.sol +0 -72
  560. package/contracts/test/TestFee.sol +0 -25
  561. package/contracts/test/TestRegisterable.sol +0 -18
  562. package/contracts/test/TestRoleId.sol +0 -14
  563. package/contracts/test/TestService.sol +0 -25
  564. package/contracts/test/TestVersion.sol +0 -44
  565. package/contracts/test/TestVersionable.sol +0 -17
  566. package/contracts/test/Usdc.sol +0 -26
  567. package/contracts/types/ChainId.sol +0 -38
  568. package/contracts/types/NumberId.sol +0 -52
  569. package/contracts/types/ObjectType.sol +0 -157
  570. package/contracts/types/RoleId.sol +0 -97
  571. /package/contracts/{types → type}/DistributorType.sol +0 -0
  572. /package/contracts/{types → type}/Key32.sol +0 -0
  573. /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
+ }