@etherisc/gif-next 0.0.2-d96b9e1-825 → 0.0.2-da06f3b-803
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.
- package/README.md +255 -8
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +656 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +849 -0
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{registry/IChainNft.sol/IChainNft.json → components/IComponent.sol/IComponent.json} +244 -241
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +648 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +429 -72
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +533 -64
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +603 -76
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +711 -67
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +66 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +24 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +42 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +764 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +185 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1137 -1023
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +592 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2001 -1098
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +1081 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1381 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1050 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +473 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +261 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +603 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +45 -127
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +55 -245
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +6 -6
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +228 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{access/IAccess.sol/IAccess.json → IDistribution.sol/IDistribution.json} +2 -2
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1102 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +449 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +772 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +437 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +715 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/IService.sol/IService.json → service/IDistributionService.sol/IDistributionService.json} +202 -61
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +766 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +198 -80
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +204 -150
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1227 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +505 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +423 -88
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +437 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +398 -215
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +437 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +186 -12
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +474 -36
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +981 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +34 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +481 -108
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1200 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +464 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +394 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +127 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +112 -37
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → shared/IService.sol/IService.json} +169 -117
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +55 -14
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +171 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +362 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +193 -32
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → shared/Service.sol/Service.json} +221 -71
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +78 -14
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +10 -10
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +207 -31
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +44 -10
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +292 -63
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +91 -53
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +12 -12
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +103 -23
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +4 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.json +376 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +52 -13
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +31 -17
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +4 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +123 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +86 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +156 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +15 -2
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +479 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +40 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
- package/contracts/components/Component.sol +216 -0
- package/contracts/components/Distribution.sol +153 -0
- package/contracts/components/IComponent.sol +43 -0
- package/contracts/components/IDistributionComponent.sol +47 -0
- package/contracts/components/IPoolComponent.sol +13 -19
- package/contracts/components/IProductComponent.sol +29 -9
- package/contracts/components/Pool.sol +105 -71
- package/contracts/components/Product.sol +189 -40
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/instance/BundleManager.sol +125 -0
- package/contracts/instance/Cloneable.sol +46 -0
- package/contracts/instance/IInstance.sol +65 -45
- package/contracts/instance/IInstanceService.sol +42 -0
- package/contracts/instance/Instance.sol +254 -53
- package/contracts/instance/InstanceAccessManager.sol +414 -0
- package/contracts/instance/InstanceReader.sol +293 -0
- package/contracts/instance/InstanceService.sol +473 -0
- package/contracts/instance/InstanceServiceManager.sol +54 -0
- package/contracts/instance/ObjectManager.sol +84 -0
- package/contracts/instance/base/ComponentService.sol +134 -0
- package/contracts/instance/base/IKeyValueStore.sol +13 -13
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +61 -36
- package/contracts/instance/base/Lifecycle.sol +16 -11
- package/contracts/instance/module/IAccess.sol +48 -0
- package/contracts/instance/module/IBundle.sol +20 -0
- package/contracts/instance/module/IDistribution.sol +39 -0
- package/contracts/instance/module/IPolicy.sol +45 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +46 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/BundleService.sol +293 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/DistributionService.sol +106 -0
- package/contracts/instance/service/DistributionServiceManager.sol +51 -0
- package/contracts/instance/service/IBundleService.sol +44 -0
- package/contracts/instance/service/IDistributionService.sol +12 -0
- package/contracts/instance/service/IPolicyService.sol +94 -0
- package/contracts/instance/service/IPoolService.sol +8 -18
- package/contracts/instance/service/IProductService.sol +21 -39
- package/contracts/instance/service/PolicyService.sol +538 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +78 -91
- package/contracts/instance/service/PoolServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +168 -289
- package/contracts/instance/service/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +79 -36
- package/contracts/registry/IRegistry.sol +67 -24
- package/contracts/registry/IRegistryService.sol +65 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +363 -287
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +262 -0
- package/contracts/registry/RegistryServiceManager.sol +62 -0
- package/contracts/registry/ReleaseManager.sol +332 -0
- package/contracts/registry/TokenRegistry.sol +112 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/ERC165.sol +6 -2
- package/contracts/shared/INftOwnable.sol +22 -0
- package/contracts/shared/IRegisterable.sol +8 -17
- package/contracts/shared/IService.sol +16 -0
- package/contracts/shared/IVersionable.sol +55 -11
- package/contracts/shared/NftOwnable.sol +139 -0
- package/contracts/shared/ProxyManager.sol +94 -0
- package/contracts/shared/Registerable.sol +59 -59
- package/contracts/shared/Service.sol +60 -0
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +113 -55
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestRoleId.sol +2 -2
- package/contracts/test/TestService.sol +7 -14
- package/contracts/test/Usdc.sol +26 -0
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +10 -5
- package/contracts/types/Key32.sol +8 -3
- package/contracts/types/NftIdSet.sol +26 -24
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +51 -14
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +68 -11
- package/contracts/types/StateId.sol +5 -1
- package/contracts/types/Timestamp.sol +7 -3
- package/contracts/types/UFixed.sol +144 -25
- package/contracts/types/Version.sol +13 -1
- package/package.json +9 -5
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -174
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -174
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +0 -300
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -63
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +0 -300
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -296
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -296
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.json +0 -10
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.json +0 -10
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.json +0 -10
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +0 -188
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -188
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -261
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -261
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -149
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -149
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -10
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -10
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -533
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -533
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -491
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -387
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -393
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +0 -453
- package/contracts/components/BaseComponent.sol +0 -88
- package/contracts/components/IBaseComponent.sol +0 -19
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/IInstanceLinked.sol +0 -8
- package/contracts/instance/base/ComponentServiceBase.sol +0 -42
- package/contracts/instance/base/IInstanceBase.sol +0 -14
- package/contracts/instance/base/IService.sol +0 -15
- package/contracts/instance/base/InstanceBase.sol +0 -80
- package/contracts/instance/base/ModuleBase.sol +0 -52
- package/contracts/instance/base/ServiceBase.sol +0 -37
- package/contracts/instance/module/access/Access.sol +0 -149
- package/contracts/instance/module/access/IAccess.sol +0 -53
- package/contracts/instance/module/bundle/BundleModule.sol +0 -136
- package/contracts/instance/module/bundle/IBundle.sol +0 -58
- package/contracts/instance/module/compensation/CompensationModule.sol +0 -8
- package/contracts/instance/module/compensation/ICompensation.sol +0 -10
- package/contracts/instance/module/component/ComponentModule.sol +0 -95
- package/contracts/instance/module/component/IComponent.sol +0 -53
- package/contracts/instance/module/policy/IPolicy.sol +0 -60
- package/contracts/instance/module/policy/PolicyModule.sol +0 -76
- package/contracts/instance/module/pool/IPoolModule.sol +0 -41
- package/contracts/instance/module/pool/PoolModule.sol +0 -87
- package/contracts/instance/module/risk/IRisk.sol +0 -10
- package/contracts/instance/module/risk/RiskModule.sol +0 -8
- package/contracts/instance/module/treasury/ITreasury.sol +0 -103
- package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
- package/contracts/instance/module/treasury/TreasuryModule.sol +0 -152
- package/contracts/instance/service/ComponentOwnerService.sol +0 -170
- package/contracts/instance/service/IComponentOwnerService.sol +0 -22
- package/contracts/registry/IChainNft.sol +0 -21
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/shared/IOwnable.sol +0 -6
- package/contracts/test/TestPool.sol +0 -22
- package/contracts/test/TestProduct.sol +0 -44
@@ -0,0 +1,414 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
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
|
+
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
8
|
+
|
9
|
+
import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE, INSTANCE_SERVICE_ROLE, INSTANCE_OWNER_ROLE} from "../types/RoleId.sol";
|
10
|
+
import {TimestampLib} from "../types/Timestamp.sol";
|
11
|
+
import {IAccess} from "./module/IAccess.sol";
|
12
|
+
|
13
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
14
|
+
|
15
|
+
contract InstanceAccessManager is
|
16
|
+
AccessManagedUpgradeable
|
17
|
+
{
|
18
|
+
using RoleIdLib for RoleId;
|
19
|
+
|
20
|
+
string public constant ADMIN_ROLE_NAME = "AdminRole";
|
21
|
+
string public constant PUBLIC_ROLE_NAME = "PublicRole";
|
22
|
+
|
23
|
+
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
|
24
|
+
uint32 public constant EXECUTION_DELAY = 0;
|
25
|
+
|
26
|
+
// role specific state
|
27
|
+
mapping(RoleId roleId => IAccess.RoleInfo info) internal _roleInfo;
|
28
|
+
mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
|
29
|
+
mapping(ShortString name => RoleId roleId) internal _roleIdForName;
|
30
|
+
RoleId [] internal _roleIds;
|
31
|
+
uint64 _idNext;
|
32
|
+
|
33
|
+
// target specific state
|
34
|
+
mapping(address target => IAccess.TargetInfo info) internal _targetInfo;
|
35
|
+
mapping(ShortString name => address target) internal _targetAddressForName;
|
36
|
+
address [] internal _targets;
|
37
|
+
|
38
|
+
AccessManager internal _accessManager;
|
39
|
+
IRegistry internal _registry;
|
40
|
+
|
41
|
+
modifier restrictedToRoleAdmin(RoleId roleId) {
|
42
|
+
RoleId admin = getRoleAdmin(roleId);
|
43
|
+
(bool inRole, uint32 executionDelay) = _accessManager.hasRole(admin.toInt(), _msgSender());
|
44
|
+
assert(executionDelay == 0); // to be sure no delayed execution functionality is used
|
45
|
+
if (!inRole) {
|
46
|
+
revert IAccess.ErrorIAccessCallerIsNotRoleAdmin(_msgSender(), roleId);
|
47
|
+
}
|
48
|
+
_;
|
49
|
+
}
|
50
|
+
|
51
|
+
function initialize(address initialAdmin, address registry) external initializer
|
52
|
+
{
|
53
|
+
// if size of the contract gets too large, this can be externalized which will reduce the contract size considerably
|
54
|
+
_accessManager = new AccessManager(address(this));
|
55
|
+
|
56
|
+
__AccessManaged_init(address(_accessManager));
|
57
|
+
|
58
|
+
_registry = IRegistry(_registry);
|
59
|
+
_idNext = CUSTOM_ROLE_ID_MIN;
|
60
|
+
|
61
|
+
_createRole(ADMIN_ROLE(), ADMIN_ROLE_NAME, false);
|
62
|
+
_createRole(PUBLIC_ROLE(), PUBLIC_ROLE_NAME, false);
|
63
|
+
|
64
|
+
// assume initialAdmin is instance service which requires admin rights to access manager during instance cloning
|
65
|
+
_accessManager.grantRole(ADMIN_ROLE().toInt(), initialAdmin, 0);
|
66
|
+
|
67
|
+
EnumerableSet.add(_roleMembers[ADMIN_ROLE()], address(this));
|
68
|
+
EnumerableSet.add(_roleMembers[ADMIN_ROLE()], initialAdmin);
|
69
|
+
}
|
70
|
+
|
71
|
+
//--- Role ------------------------------------------------------//
|
72
|
+
// INSTANCE_SERVICE_ROLE
|
73
|
+
// creates core or gif roles
|
74
|
+
// assume core roles are never revoked or renounced -> core roles admin is never active after intialization
|
75
|
+
// assume gif roles can be revoked or renounced
|
76
|
+
function createRole(RoleId roleId, string memory name, RoleId admin)
|
77
|
+
external
|
78
|
+
restricted()
|
79
|
+
{
|
80
|
+
bool isCustom = false;
|
81
|
+
_validateRoleParameters(roleId, name, isCustom);
|
82
|
+
_createRole(roleId, name, isCustom);
|
83
|
+
setRoleAdmin(roleId, admin);
|
84
|
+
}
|
85
|
+
|
86
|
+
// INSTANCE_OWNER_ROLE
|
87
|
+
// creates custom roles only
|
88
|
+
// TODO INSTANCE_OWNER_ROLE as default admin
|
89
|
+
function createCustomRole(string memory name, RoleId admin)
|
90
|
+
external
|
91
|
+
restricted()
|
92
|
+
returns(RoleId roleId)
|
93
|
+
{
|
94
|
+
bool isCustom = true;
|
95
|
+
RoleId roleId = _getNextCustomRoleId();
|
96
|
+
_validateRoleParameters(roleId, name, isCustom);
|
97
|
+
_createRole(roleId, name, isCustom);
|
98
|
+
setRoleAdmin(roleId, admin);
|
99
|
+
}
|
100
|
+
|
101
|
+
// TODO MUST always be restricted to ADMIN_ROLE? -> use onlyAdminRole or use similar _getAdminRestrictions()
|
102
|
+
function setRoleAdmin(RoleId roleId, RoleId admin)
|
103
|
+
public
|
104
|
+
restricted()
|
105
|
+
{
|
106
|
+
if (!roleExists(roleId)) {
|
107
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
108
|
+
}
|
109
|
+
|
110
|
+
if (!roleExists(admin)) {
|
111
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(admin);
|
112
|
+
}
|
113
|
+
|
114
|
+
_roleInfo[roleId].admin = admin;
|
115
|
+
}
|
116
|
+
|
117
|
+
// TODO notify member?
|
118
|
+
// TODO granting/revoking can be `attached` to nft transfer?
|
119
|
+
function grantRole(RoleId roleId, address member)
|
120
|
+
external
|
121
|
+
restrictedToRoleAdmin(roleId)
|
122
|
+
returns (bool granted)
|
123
|
+
{
|
124
|
+
if (!roleExists(roleId)) {
|
125
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
126
|
+
}
|
127
|
+
|
128
|
+
granted = EnumerableSet.add(_roleMembers[roleId], member);
|
129
|
+
if(granted) {
|
130
|
+
_accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
|
131
|
+
|
132
|
+
}
|
133
|
+
}
|
134
|
+
|
135
|
+
function revokeRole(RoleId roleId, address member)
|
136
|
+
external
|
137
|
+
restrictedToRoleAdmin(roleId)
|
138
|
+
returns (bool)
|
139
|
+
{
|
140
|
+
return _revokeRole(roleId, member);
|
141
|
+
}
|
142
|
+
|
143
|
+
/// @dev not restricted function by intention
|
144
|
+
/// the restriction to role members is already enforced by the call to the access manager
|
145
|
+
function renounceRole(RoleId roleId)
|
146
|
+
external
|
147
|
+
returns (bool)
|
148
|
+
{
|
149
|
+
address member = msg.sender;
|
150
|
+
// cannot use accessManger.renounce as it directly checks against msg.sender
|
151
|
+
return _revokeRole(roleId, member);
|
152
|
+
}
|
153
|
+
|
154
|
+
function roleExists(RoleId roleId) public view returns (bool exists) {
|
155
|
+
return _roleInfo[roleId].createdAt.gtz();
|
156
|
+
}
|
157
|
+
|
158
|
+
function getRoleAdmin(RoleId roleId) public view returns(RoleId admin) {
|
159
|
+
return _roleInfo[roleId].admin;
|
160
|
+
}
|
161
|
+
|
162
|
+
function getRoleInfo(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
|
163
|
+
return _roleInfo[roleId];
|
164
|
+
}
|
165
|
+
|
166
|
+
function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
|
167
|
+
return EnumerableSet.length(_roleMembers[roleId]);
|
168
|
+
}
|
169
|
+
|
170
|
+
function getRoleId(uint256 idx) external view returns (RoleId roleId) {
|
171
|
+
return _roleIds[idx];
|
172
|
+
}
|
173
|
+
|
174
|
+
function getRoleIdForName(string memory name) external view returns (RoleId roleId) {
|
175
|
+
return _roleIdForName[ShortStrings.toShortString(name)];
|
176
|
+
}
|
177
|
+
|
178
|
+
function roleMember(RoleId roleId, uint256 idx) external view returns (address roleMember) {
|
179
|
+
return EnumerableSet.at(_roleMembers[roleId], idx);
|
180
|
+
}
|
181
|
+
|
182
|
+
function hasRole(RoleId roleId, address account) external view returns (bool accountHasRole) {
|
183
|
+
(accountHasRole, ) = _accessManager.hasRole(roleId.toInt(), account);
|
184
|
+
}
|
185
|
+
|
186
|
+
function roles() external view returns (uint256 numberOfRoles) {
|
187
|
+
return _roleIds.length;
|
188
|
+
}
|
189
|
+
|
190
|
+
//--- Target ------------------------------------------------------//
|
191
|
+
// INSTANCE_SERVICE_ROLE
|
192
|
+
function createTarget(address target, string memory name) external restricted() {
|
193
|
+
bool isCustom = false;
|
194
|
+
_createTarget(target, name, isCustom);
|
195
|
+
}
|
196
|
+
// INSTANCE_OWNER_ROLE
|
197
|
+
function createCustomTarget(address target, string memory name)
|
198
|
+
external
|
199
|
+
restricted()
|
200
|
+
{
|
201
|
+
// TODO custom targets can not be registered before this function, but possibly can after...
|
202
|
+
if(_registry.isRegistered(target)) {
|
203
|
+
revert IAccess.ErrorIAccessTargetIsRegistered(target);
|
204
|
+
}
|
205
|
+
|
206
|
+
bool isCustom = true;
|
207
|
+
_createTarget(target, name, isCustom);
|
208
|
+
}
|
209
|
+
// INSTANCE_SERVICE_ROLE
|
210
|
+
function setTargetLocked(string memory targetName, bool locked)
|
211
|
+
external
|
212
|
+
restricted()
|
213
|
+
{
|
214
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
215
|
+
address target = _targetAddressForName[nameShort];
|
216
|
+
|
217
|
+
if (target == address(0)) {
|
218
|
+
revert IAccess.ErrorIAccessTargetDoesNotExist(nameShort);
|
219
|
+
}
|
220
|
+
|
221
|
+
// TODO setLocked() for gif and custom targets but NEVER for core targets
|
222
|
+
/*if(!_targetInfo[target].isCustom) {
|
223
|
+
revert IAccess.ErrorIAccessSetLockedForNoncustomTarget(target);
|
224
|
+
}*/
|
225
|
+
// TODO isLocked is redundant but makes getTargetInfo() faster
|
226
|
+
_targetInfo[target].isLocked = locked;
|
227
|
+
_accessManager.setTargetClosed(target, locked);
|
228
|
+
}
|
229
|
+
|
230
|
+
// allowed combinations of roles and targets:
|
231
|
+
//1) set core role for core target
|
232
|
+
//2) set gif role for gif target
|
233
|
+
//3) set custom role for gif target
|
234
|
+
//4) set custom role for custom target
|
235
|
+
|
236
|
+
// ADMIN_ROLE if used only during initialization, works with:
|
237
|
+
// any roles for any targets
|
238
|
+
// INSTANCE_SERVICE_ROLE if used not only during initilization, works with:
|
239
|
+
// core roles for core targets
|
240
|
+
// gif roles for gif targets
|
241
|
+
function setTargetFunctionRole(
|
242
|
+
string memory targetName,
|
243
|
+
bytes4[] calldata selectors,
|
244
|
+
RoleId roleId
|
245
|
+
)
|
246
|
+
public
|
247
|
+
virtual
|
248
|
+
restricted()
|
249
|
+
{
|
250
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
251
|
+
address target = _targetAddressForName[nameShort];
|
252
|
+
|
253
|
+
if (target == address(0)) {
|
254
|
+
revert IAccess.ErrorIAccessTargetDoesNotExist(nameShort);
|
255
|
+
}
|
256
|
+
|
257
|
+
if (!roleExists(roleId)) {
|
258
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
259
|
+
}
|
260
|
+
|
261
|
+
uint64 roleIdInt = RoleId.unwrap(roleId);
|
262
|
+
_accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
|
263
|
+
}
|
264
|
+
// INSTANCE_OWNER_ROLE
|
265
|
+
// custom role for gif target -> instance owner can mess with gif target (component) -> e.g. set custom role for function intendent to work with gif role
|
266
|
+
// custom role for custom target
|
267
|
+
function setTargetFunctionCustomRole(
|
268
|
+
string memory targetName,
|
269
|
+
bytes4[] calldata selectors,
|
270
|
+
RoleId roleId
|
271
|
+
) public virtual restricted() {
|
272
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
273
|
+
address target = _targetAddressForName[nameShort];
|
274
|
+
if (target == address(0)) {
|
275
|
+
revert IAccess.ErrorIAccessTargetDoesNotExist(nameShort);
|
276
|
+
}
|
277
|
+
|
278
|
+
// TODO set for gif and custom targets but NEVER for core targets
|
279
|
+
/*if(!_targetInfo[target].isCustom) {
|
280
|
+
revert IAccess.ErrorIAccessSetForNoncustomTarget(target);
|
281
|
+
}*/
|
282
|
+
|
283
|
+
if (!roleExists(roleId)) {
|
284
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
285
|
+
}
|
286
|
+
|
287
|
+
// TODO set for gif and custom roles
|
288
|
+
/*if(!_roleInfo[roleId].isCustom) {
|
289
|
+
revert IAccess.ErrorIAccessSetNoncustomRole(roleId);
|
290
|
+
}*/
|
291
|
+
|
292
|
+
uint64 roleIdInt = RoleId.unwrap(roleId);
|
293
|
+
_accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
|
294
|
+
}
|
295
|
+
|
296
|
+
function isTargetLocked(address target) public view returns (bool locked) {
|
297
|
+
return _accessManager.isTargetClosed(target);
|
298
|
+
}
|
299
|
+
|
300
|
+
function targetExists(address target) public view returns (bool exists) {
|
301
|
+
return _targetInfo[target].createdAt.gtz();
|
302
|
+
}
|
303
|
+
|
304
|
+
function getTargetInfo(address target) public view returns (IAccess.TargetInfo memory) {
|
305
|
+
return _targetInfo[target];
|
306
|
+
}
|
307
|
+
|
308
|
+
//--- internal view/pure functions --------------------------------------//
|
309
|
+
|
310
|
+
function _createRole(RoleId roleId, string memory name, bool isCustom)
|
311
|
+
internal
|
312
|
+
{
|
313
|
+
IAccess.RoleInfo memory role = IAccess.RoleInfo(
|
314
|
+
ShortStrings.toShortString(name),
|
315
|
+
isCustom,
|
316
|
+
ADMIN_ROLE(),
|
317
|
+
TimestampLib.blockTimestamp(),
|
318
|
+
TimestampLib.blockTimestamp());
|
319
|
+
|
320
|
+
_roleInfo[roleId] = role;
|
321
|
+
_roleIdForName[role.name] = roleId;
|
322
|
+
_roleIds.push(roleId);
|
323
|
+
}
|
324
|
+
|
325
|
+
function _validateRoleParameters(
|
326
|
+
RoleId roleId,
|
327
|
+
string memory name,
|
328
|
+
bool isCustom
|
329
|
+
)
|
330
|
+
internal
|
331
|
+
view
|
332
|
+
returns (IAccess.RoleInfo memory existingRole)
|
333
|
+
{
|
334
|
+
if(roleExists(roleId)) {
|
335
|
+
revert IAccess.ErrorIAccessRoleIdAlreadyExists(roleId);
|
336
|
+
}
|
337
|
+
|
338
|
+
uint roleIdInt = roleId.toInt();
|
339
|
+
if (isCustom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
|
340
|
+
revert IAccess.ErrorIAccessRoleIdTooSmall(roleId);
|
341
|
+
} else if (!isCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
|
342
|
+
revert IAccess.ErrorIAccessRoleIdTooBig(roleId);
|
343
|
+
}
|
344
|
+
|
345
|
+
// role name checks
|
346
|
+
ShortString nameShort = ShortStrings.toShortString(name);
|
347
|
+
if (ShortStrings.byteLength(nameShort) == 0) {
|
348
|
+
revert IAccess.ErrorIAccessRoleNameEmpty(roleId);
|
349
|
+
}
|
350
|
+
|
351
|
+
if (_roleIdForName[nameShort].gtz()) {
|
352
|
+
revert IAccess.ErrorIAccessRoleNameNotUnique(_roleIdForName[nameShort], nameShort);
|
353
|
+
}
|
354
|
+
}
|
355
|
+
|
356
|
+
function _revokeRole(RoleId roleId, address member)
|
357
|
+
internal
|
358
|
+
returns(bool revoked)
|
359
|
+
{
|
360
|
+
if (!roleExists(roleId)) {
|
361
|
+
revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
|
362
|
+
}
|
363
|
+
|
364
|
+
revoked = EnumerableSet.remove(_roleMembers[roleId], member);
|
365
|
+
if(revoked) {
|
366
|
+
_accessManager.revokeRole(roleId.toInt(), member);
|
367
|
+
}
|
368
|
+
}
|
369
|
+
|
370
|
+
function _getNextCustomRoleId() internal returns(RoleId) {
|
371
|
+
return RoleIdLib.toRoleId(_idNext++);
|
372
|
+
}
|
373
|
+
|
374
|
+
function _createTarget(address target, string memory name, bool isCustom) internal {
|
375
|
+
_validateTargetParameters(target, name, isCustom);
|
376
|
+
|
377
|
+
IAccess.TargetInfo memory info = IAccess.TargetInfo(
|
378
|
+
ShortStrings.toShortString(name),
|
379
|
+
isCustom,
|
380
|
+
_accessManager.isTargetClosed(target), // sync with state in access manager
|
381
|
+
TimestampLib.blockTimestamp(),
|
382
|
+
TimestampLib.blockTimestamp());
|
383
|
+
|
384
|
+
_targetInfo[target] = info;
|
385
|
+
_targetAddressForName[info.name] = target;
|
386
|
+
_targets.push(target);
|
387
|
+
}
|
388
|
+
|
389
|
+
function _validateTargetParameters(address target, string memory name, bool isCustom) internal view {
|
390
|
+
if (_targetInfo[target].createdAt.gtz()) {
|
391
|
+
revert IAccess.ErrorIAccessTargetAlreadyExists(target, _targetInfo[target].name);
|
392
|
+
}
|
393
|
+
|
394
|
+
ShortString nameShort = ShortStrings.toShortString(name);
|
395
|
+
if (ShortStrings.byteLength(nameShort) == 0) {
|
396
|
+
revert IAccess.ErrorIAccessTargetNameEmpty(target);
|
397
|
+
}
|
398
|
+
|
399
|
+
if (_targetAddressForName[nameShort] != address(0)) {
|
400
|
+
revert IAccess.ErrorIAccessTargetNameExists(
|
401
|
+
target,
|
402
|
+
_targetAddressForName[nameShort],
|
403
|
+
nameShort);
|
404
|
+
}
|
405
|
+
}
|
406
|
+
|
407
|
+
function canCall(
|
408
|
+
address caller,
|
409
|
+
address target,
|
410
|
+
bytes4 selector
|
411
|
+
) public view virtual returns (bool immediate, uint32 delay) {
|
412
|
+
return _accessManager.canCall(caller, target, selector);
|
413
|
+
}
|
414
|
+
}
|
@@ -0,0 +1,293 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
6
|
+
import {DistributorType} from "../types/DistributorType.sol";
|
7
|
+
import {Fee, FeeLib} from "../types/Fee.sol";
|
8
|
+
import {Key32} from "../types/Key32.sol";
|
9
|
+
import {NftId} from "../types/NftId.sol";
|
10
|
+
import {ObjectType, DISTRIBUTOR, DISTRIBUTION, INSTANCE, PRODUCT, POLICY, POOL, TREASURY, BUNDLE} from "../types/ObjectType.sol";
|
11
|
+
import {ReferralId, ReferralStatus, ReferralLib, REFERRAL_OK, REFERRAL_ERROR_UNKNOWN, REFERRAL_ERROR_EXPIRED, REFERRAL_ERROR_EXHAUSTED} from "../types/Referral.sol";
|
12
|
+
import {Registerable} from "../shared/Registerable.sol";
|
13
|
+
import {RiskId} from "../types/RiskId.sol";
|
14
|
+
import {UFixed, MathLib, UFixedLib} from "../types/UFixed.sol";
|
15
|
+
import {Version} from "../types/Version.sol";
|
16
|
+
import {StateId} from "../types/StateId.sol";
|
17
|
+
|
18
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
19
|
+
import {IBundle} from "../instance/module/IBundle.sol";
|
20
|
+
import {IDistribution} from "../instance/module/IDistribution.sol";
|
21
|
+
import {IInstance} from "./IInstance.sol";
|
22
|
+
import {IKeyValueStore} from "../instance/base/IKeyValueStore.sol";
|
23
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
24
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
25
|
+
import {ISetup} from "../instance/module/ISetup.sol";
|
26
|
+
import {ITreasury} from "../instance/module/ITreasury.sol";
|
27
|
+
import {TimestampLib} from "../types/Timestamp.sol";
|
28
|
+
|
29
|
+
|
30
|
+
contract InstanceReader {
|
31
|
+
bool private _initialized;
|
32
|
+
|
33
|
+
IRegistry internal _registry;
|
34
|
+
IInstance internal _instance;
|
35
|
+
IKeyValueStore internal _store;
|
36
|
+
|
37
|
+
function initialize(address registry, address instance) public {
|
38
|
+
require(!_initialized, "ERROR:CRD-000:ALREADY_INITIALIZED");
|
39
|
+
|
40
|
+
require(
|
41
|
+
address(registry) != address(0),
|
42
|
+
"ERROR:CRD-001:REGISTRY_ZERO");
|
43
|
+
|
44
|
+
|
45
|
+
_registry = IRegistry(registry);
|
46
|
+
|
47
|
+
_instance = IInstance(instance);
|
48
|
+
_store = IKeyValueStore(instance);
|
49
|
+
|
50
|
+
_initialized = true;
|
51
|
+
}
|
52
|
+
|
53
|
+
|
54
|
+
// module specific functions
|
55
|
+
|
56
|
+
function getPolicyInfo(NftId policyNftId)
|
57
|
+
public
|
58
|
+
view
|
59
|
+
returns (IPolicy.PolicyInfo memory info)
|
60
|
+
{
|
61
|
+
bytes memory data = _store.getData(toPolicyKey(policyNftId));
|
62
|
+
if (data.length > 0) {
|
63
|
+
return abi.decode(data, (IPolicy.PolicyInfo));
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
function getPolicyState(NftId policyNftId)
|
68
|
+
public
|
69
|
+
view
|
70
|
+
returns (StateId state)
|
71
|
+
{
|
72
|
+
return _instance.getState(toPolicyKey(policyNftId));
|
73
|
+
}
|
74
|
+
|
75
|
+
function getRiskInfo(RiskId riskId)
|
76
|
+
public
|
77
|
+
view
|
78
|
+
returns (IRisk.RiskInfo memory info)
|
79
|
+
{
|
80
|
+
bytes memory data = _store.getData(riskId.toKey32());
|
81
|
+
if (data.length > 0) {
|
82
|
+
return abi.decode(data, (IRisk.RiskInfo));
|
83
|
+
}
|
84
|
+
}
|
85
|
+
|
86
|
+
function getTokenHandler(NftId productNftId)
|
87
|
+
public
|
88
|
+
view
|
89
|
+
returns (address tokenHandler)
|
90
|
+
{
|
91
|
+
bytes memory data = _store.getData(toTreasuryKey(productNftId));
|
92
|
+
|
93
|
+
if (data.length > 0) {
|
94
|
+
ITreasury.TreasuryInfo memory info = abi.decode(data, (ITreasury.TreasuryInfo));
|
95
|
+
return address(info.tokenHandler);
|
96
|
+
}
|
97
|
+
}
|
98
|
+
|
99
|
+
function getTreasuryInfo(NftId productNftId)
|
100
|
+
public
|
101
|
+
view
|
102
|
+
returns (ITreasury.TreasuryInfo memory info)
|
103
|
+
{
|
104
|
+
bytes memory data = _store.getData(toTreasuryKey(productNftId));
|
105
|
+
if (data.length > 0) {
|
106
|
+
return abi.decode(data, (ITreasury.TreasuryInfo));
|
107
|
+
}
|
108
|
+
}
|
109
|
+
|
110
|
+
function getBundleInfo(NftId bundleNftId)
|
111
|
+
public
|
112
|
+
view
|
113
|
+
returns (IBundle.BundleInfo memory info)
|
114
|
+
{
|
115
|
+
bytes memory data = _store.getData(toBundleKey(bundleNftId));
|
116
|
+
if (data.length > 0) {
|
117
|
+
return abi.decode(data, (IBundle.BundleInfo));
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
function getDistributorTypeInfo(DistributorType distributorType)
|
122
|
+
public
|
123
|
+
view
|
124
|
+
returns (IDistribution.DistributorTypeInfo memory info)
|
125
|
+
{
|
126
|
+
bytes memory data = _store.getData(distributorType.toKey32());
|
127
|
+
if (data.length > 0) {
|
128
|
+
return abi.decode(data, (IDistribution.DistributorTypeInfo));
|
129
|
+
}
|
130
|
+
}
|
131
|
+
|
132
|
+
function getDistributorInfo(NftId distributorNftId)
|
133
|
+
public
|
134
|
+
view
|
135
|
+
returns (IDistribution.DistributorInfo memory info)
|
136
|
+
{
|
137
|
+
bytes memory data = _store.getData(toDistributorKey(distributorNftId));
|
138
|
+
if (data.length > 0) {
|
139
|
+
return abi.decode(data, (IDistribution.DistributorInfo));
|
140
|
+
}
|
141
|
+
}
|
142
|
+
|
143
|
+
function getDistributionSetupInfo(NftId distributionNftId)
|
144
|
+
public
|
145
|
+
view
|
146
|
+
returns (ISetup.DistributionSetupInfo memory info)
|
147
|
+
{
|
148
|
+
bytes memory data = _store.getData(toDistributionKey(distributionNftId));
|
149
|
+
if (data.length > 0) {
|
150
|
+
return abi.decode(data, (ISetup.DistributionSetupInfo));
|
151
|
+
}
|
152
|
+
}
|
153
|
+
|
154
|
+
function getPoolSetupInfo(NftId poolNftId)
|
155
|
+
public
|
156
|
+
view
|
157
|
+
returns (ISetup.PoolSetupInfo memory info)
|
158
|
+
{
|
159
|
+
bytes memory data = _store.getData(toPoolKey(poolNftId));
|
160
|
+
if (data.length > 0) {
|
161
|
+
return abi.decode(data, (ISetup.PoolSetupInfo));
|
162
|
+
}
|
163
|
+
}
|
164
|
+
|
165
|
+
function getProductSetupInfo(NftId productNftId)
|
166
|
+
public
|
167
|
+
view
|
168
|
+
returns (ISetup.ProductSetupInfo memory info)
|
169
|
+
{
|
170
|
+
bytes memory data = _store.getData(toProductKey(productNftId));
|
171
|
+
if (data.length > 0) {
|
172
|
+
return abi.decode(data, (ISetup.ProductSetupInfo));
|
173
|
+
}
|
174
|
+
}
|
175
|
+
|
176
|
+
function getReferralInfo(ReferralId referralId)
|
177
|
+
public
|
178
|
+
view
|
179
|
+
returns (IDistribution.ReferralInfo memory info)
|
180
|
+
{
|
181
|
+
bytes memory data = _store.getData(referralId.toKey32());
|
182
|
+
if (data.length > 0) {
|
183
|
+
return abi.decode(data, (IDistribution.ReferralInfo));
|
184
|
+
}
|
185
|
+
}
|
186
|
+
|
187
|
+
|
188
|
+
function getMetadata(Key32 key)
|
189
|
+
public
|
190
|
+
view
|
191
|
+
returns (IKeyValueStore.Metadata memory metadata)
|
192
|
+
{
|
193
|
+
return _store.getMetadata(key);
|
194
|
+
}
|
195
|
+
|
196
|
+
|
197
|
+
function toReferralId(
|
198
|
+
NftId distributionNftId,
|
199
|
+
string memory referralCode
|
200
|
+
)
|
201
|
+
public
|
202
|
+
pure
|
203
|
+
returns (ReferralId referralId)
|
204
|
+
{
|
205
|
+
return ReferralLib.toReferralId(
|
206
|
+
distributionNftId,
|
207
|
+
referralCode);
|
208
|
+
}
|
209
|
+
|
210
|
+
|
211
|
+
function getDiscountPercentage(ReferralId referralId)
|
212
|
+
public
|
213
|
+
view
|
214
|
+
returns (
|
215
|
+
UFixed discountPercentage,
|
216
|
+
ReferralStatus status
|
217
|
+
)
|
218
|
+
{
|
219
|
+
IDistribution.ReferralInfo memory info = getReferralInfo(
|
220
|
+
referralId);
|
221
|
+
|
222
|
+
if (info.expiryAt.eqz()) {
|
223
|
+
return (
|
224
|
+
UFixedLib.zero(),
|
225
|
+
REFERRAL_ERROR_UNKNOWN());
|
226
|
+
}
|
227
|
+
|
228
|
+
if (info.expiryAt < TimestampLib.blockTimestamp()) {
|
229
|
+
return (
|
230
|
+
UFixedLib.zero(),
|
231
|
+
REFERRAL_ERROR_EXPIRED());
|
232
|
+
}
|
233
|
+
|
234
|
+
if (info.usedReferrals >= info.maxReferrals) {
|
235
|
+
return (
|
236
|
+
UFixedLib.zero(),
|
237
|
+
REFERRAL_ERROR_EXHAUSTED());
|
238
|
+
}
|
239
|
+
|
240
|
+
return (
|
241
|
+
info.discountPercentage,
|
242
|
+
REFERRAL_OK()
|
243
|
+
);
|
244
|
+
}
|
245
|
+
|
246
|
+
|
247
|
+
function toTreasuryKey(NftId productNftId) public pure returns (Key32) {
|
248
|
+
return productNftId.toKey32(TREASURY());
|
249
|
+
}
|
250
|
+
|
251
|
+
|
252
|
+
function toPolicyKey(NftId policyNftId) public pure returns (Key32) {
|
253
|
+
return policyNftId.toKey32(POLICY());
|
254
|
+
}
|
255
|
+
|
256
|
+
|
257
|
+
function toDistributorKey(NftId distributorNftId) public pure returns (Key32) {
|
258
|
+
return distributorNftId.toKey32(DISTRIBUTOR());
|
259
|
+
}
|
260
|
+
|
261
|
+
function toDistributionKey(NftId distributionNftId) public pure returns (Key32) {
|
262
|
+
return distributionNftId.toKey32(DISTRIBUTION());
|
263
|
+
}
|
264
|
+
|
265
|
+
function toBundleKey(NftId poolNftId) public pure returns (Key32) {
|
266
|
+
return poolNftId.toKey32(BUNDLE());
|
267
|
+
}
|
268
|
+
|
269
|
+
function toPoolKey(NftId poolNftId) public pure returns (Key32) {
|
270
|
+
return poolNftId.toKey32(POOL());
|
271
|
+
}
|
272
|
+
|
273
|
+
function toProductKey(NftId productNftId) public pure returns (Key32) {
|
274
|
+
return productNftId.toKey32(PRODUCT());
|
275
|
+
}
|
276
|
+
|
277
|
+
// low level function
|
278
|
+
function getInstance() external view returns (IInstance instance) {
|
279
|
+
return _instance;
|
280
|
+
}
|
281
|
+
|
282
|
+
function getInstanceStore() external view returns (IKeyValueStore store) {
|
283
|
+
return _store;
|
284
|
+
}
|
285
|
+
|
286
|
+
function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
|
287
|
+
return UFixedLib.toUFixed(value, exp);
|
288
|
+
}
|
289
|
+
|
290
|
+
function toInt(UFixed value) public pure returns (uint256) {
|
291
|
+
return UFixedLib.toInt(value);
|
292
|
+
}
|
293
|
+
}
|