@etherisc/gif-next 0.0.2-eb7397c → 0.0.2-eb98db7-932
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 +436 -8
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.json +705 -31
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +1346 -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} +284 -223
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +900 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +887 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +806 -0
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +1184 -75
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +1105 -90
- 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 +2102 -510
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +498 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2780 -459
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +984 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1386 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1035 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +693 -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 +541 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +429 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.json +115 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +502 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +169 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +254 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/{access/IAccess.sol/IAccess.json → module/IBundle.sol/IBundle.json} +2 -2
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.json +10 -0
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module}/IPolicy.sol/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool/IPoolModule.sol/IPool.json → module/IRisk.sol/IRisk.json} +2 -2
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponent.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/ITreasury.sol/ITreasury.json +10 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +858 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +657 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1085 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +661 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +743 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1087 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +729 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +462 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +622 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +398 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +520 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +572 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +336 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +373 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1109 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +717 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +716 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +649 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +766 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +649 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +239 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +519 -61
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +879 -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 +567 -75
- 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 +1166 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +670 -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 +498 -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 +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +73 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/{registry/Registry.sol/Registerable.json → shared/INftOwnable.sol/INftOwnable.json} +46 -74
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/{instance/product/IProductService.sol/IProductService.json → shared/IPolicyHolder.sol/IPolicyHolder.json} +68 -53
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/{instance/pool/PoolModule.sol/PoolModule.json → shared/IRegisterable.sol/IRegisterable.json} +106 -80
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IRegistryLinked.sol}/IRegistryLinked.json +18 -19
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/shared/IService.sol/IService.json +258 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +55 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +251 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +582 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +352 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/shared/Service.sol/Service.json +414 -0
- 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 +4 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +78 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +4 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +119 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +4 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +383 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +4 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +116 -0
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +4 -0
- package/artifacts/contracts/test/TestService.sol/TestService.json +510 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +4 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +376 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +218 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +104 -0
- 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 +4 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +10 -0
- 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/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
- 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 +4 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +257 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +125 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +65 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +33 -0
- 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 +4 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +92 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
- 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 +4 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +92 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +77 -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 +4 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.json +177 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +49 -0
- package/contracts/components/Component.sol +216 -37
- package/contracts/components/Distribution.sol +287 -0
- package/contracts/components/IComponent.sol +54 -0
- package/contracts/components/IDistributionComponent.sol +92 -0
- package/contracts/components/IPoolComponent.sol +87 -0
- package/contracts/components/IProductComponent.sol +39 -0
- package/contracts/components/Pool.sol +242 -17
- package/contracts/components/Product.sol +251 -32
- package/contracts/instance/BundleManager.sol +125 -0
- package/contracts/instance/Cloneable.sol +46 -0
- package/contracts/instance/IInstance.sol +87 -15
- package/contracts/instance/IInstanceService.sol +59 -0
- package/contracts/instance/Instance.sol +270 -43
- package/contracts/instance/InstanceAccessManager.sol +297 -0
- package/contracts/instance/InstanceReader.sol +293 -0
- package/contracts/instance/InstanceService.sol +476 -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 +49 -0
- package/contracts/instance/base/ILifecycle.sol +30 -0
- package/contracts/instance/base/KeyValueStore.sol +172 -0
- package/contracts/instance/base/Lifecycle.sol +100 -0
- package/contracts/instance/module/IAccess.sol +47 -0
- package/contracts/instance/module/IBundle.sol +20 -0
- package/contracts/instance/module/IDistribution.sol +40 -0
- package/contracts/instance/module/IPolicy.sol +47 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +48 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/ApplicationService.sol +268 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +298 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/ClaimService.sol +151 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +346 -0
- package/contracts/instance/service/DistributionServiceManager.sol +51 -0
- package/contracts/instance/service/IApplicationService.sol +82 -0
- package/contracts/instance/service/IBundleService.sol +54 -0
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +73 -0
- package/contracts/instance/service/IPolicyService.sol +89 -0
- package/contracts/instance/service/IPoolService.sol +20 -0
- package/contracts/instance/service/IProductService.sol +40 -0
- package/contracts/instance/service/PolicyService.sol +476 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +109 -0
- package/contracts/instance/service/PoolServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +233 -0
- package/contracts/instance/service/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +138 -109
- package/contracts/registry/IRegistry.sol +78 -49
- package/contracts/registry/IRegistryService.sol +67 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +398 -116
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +283 -0
- package/contracts/registry/RegistryServiceManager.sol +62 -0
- package/contracts/registry/ReleaseManager.sol +322 -0
- package/contracts/registry/TokenRegistry.sol +116 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/ERC165.sol +27 -0
- package/contracts/shared/INftOwnable.sol +23 -0
- package/contracts/shared/IPolicyHolder.sol +26 -0
- package/contracts/shared/IRegisterable.sol +15 -0
- package/contracts/shared/IRegistryLinked.sol +12 -0
- package/contracts/shared/IService.sol +16 -0
- package/contracts/shared/IVersionable.sol +53 -0
- package/contracts/shared/NftOwnable.sol +120 -0
- package/contracts/shared/PolicyHolder.sol +81 -0
- package/contracts/shared/ProxyManager.sol +169 -0
- package/contracts/shared/Registerable.sol +74 -0
- package/contracts/shared/RegistryLinked.sol +48 -0
- package/contracts/shared/Service.sol +58 -0
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +59 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestRegisterable.sol +18 -0
- package/contracts/test/TestRoleId.sol +14 -0
- package/contracts/test/TestService.sol +25 -0
- package/contracts/test/TestToken.sol +26 -0
- package/contracts/test/TestVersion.sol +44 -0
- package/contracts/test/TestVersionable.sol +17 -0
- package/contracts/test/Usdc.sol +26 -0
- package/contracts/types/AddressSet.sol +58 -0
- package/contracts/types/Blocknumber.sol +76 -18
- package/contracts/types/ChainId.sol +18 -10
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +56 -0
- package/contracts/types/Key32.sol +50 -0
- package/contracts/types/NftId.sol +48 -11
- package/contracts/types/NftIdSet.sol +62 -0
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +156 -0
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +90 -0
- package/contracts/types/StateId.sol +105 -0
- package/contracts/types/Timestamp.sol +89 -17
- package/contracts/types/UFixed.sol +193 -75
- package/contracts/types/Version.sol +107 -0
- package/package.json +21 -6
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +0 -35
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.json +0 -179
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +0 -192
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.json +0 -400
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.json +0 -35
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.json +0 -50
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.json +0 -336
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.json +0 -327
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +0 -147
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.json +0 -179
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +0 -245
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +0 -94
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.json +0 -24
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.json +0 -231
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +0 -231
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.json +0 -149
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.json +0 -75
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.json +0 -75
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -167
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.json +0 -24
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.json +0 -166
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +0 -60
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +0 -440
- package/contracts/components/IPool.sol +0 -9
- package/contracts/components/IProduct.sol +0 -12
- package/contracts/experiment/errors/Require.sol +0 -33
- package/contracts/experiment/errors/Revert.sol +0 -39
- package/contracts/experiment/inheritance/A.sol +0 -56
- package/contracts/experiment/inheritance/B.sol +0 -23
- package/contracts/experiment/inheritance/C.sol +0 -28
- package/contracts/experiment/inheritance/IA.sol +0 -18
- package/contracts/experiment/inheritance/IB.sol +0 -9
- package/contracts/experiment/inheritance/IC.sol +0 -11
- package/contracts/experiment/types/TypeA.sol +0 -42
- package/contracts/experiment/types/TypeB.sol +0 -24
- package/contracts/instance/access/Access.sol +0 -218
- package/contracts/instance/access/IAccess.sol +0 -83
- package/contracts/instance/component/ComponentModule.sol +0 -248
- package/contracts/instance/component/IComponent.sol +0 -95
- package/contracts/instance/policy/IPolicy.sol +0 -66
- package/contracts/instance/policy/PolicyModule.sol +0 -107
- package/contracts/instance/pool/IPoolModule.sol +0 -41
- package/contracts/instance/pool/PoolModule.sol +0 -86
- package/contracts/instance/product/IProductService.sol +0 -46
- package/contracts/instance/product/ProductService.sol +0 -108
- package/contracts/registry/IChainNft.sol +0 -18
@@ -1,18 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IB} from "./IB.sol";
|
5
|
-
import {IC} from "./IC.sol";
|
6
|
-
|
7
|
-
interface ISharedA {
|
8
|
-
|
9
|
-
function getA() external view returns(uint256);
|
10
|
-
function setA(uint256 newA) external;
|
11
|
-
}
|
12
|
-
|
13
|
-
interface IA is
|
14
|
-
ISharedA,
|
15
|
-
IB,
|
16
|
-
IC
|
17
|
-
{
|
18
|
-
}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
interface IC {
|
5
|
-
|
6
|
-
function getAfromC() external view returns(uint256);
|
7
|
-
function getBfromC() external view returns(uint256);
|
8
|
-
|
9
|
-
function getC() external view returns(uint256);
|
10
|
-
function setC(uint256 newA) external;
|
11
|
-
}
|
@@ -1,42 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
/*
|
5
|
-
# chisel session for user defined types
|
6
|
-
|
7
|
-
import {TypeA, toTypeA} from "./contracts/experiment/types/TypeA.sol";
|
8
|
-
TypeA a = toTypeA(1);
|
9
|
-
TypeA b = toTypeA(2);
|
10
|
-
uint(a.toInt())
|
11
|
-
uint(b.toInt())
|
12
|
-
a == b
|
13
|
-
a != b
|
14
|
-
|
15
|
-
import {TypeB, toTypeB} from "./contracts/experiment/types/TypeB.sol";
|
16
|
-
TypeB x = toTypeB(33);
|
17
|
-
uint(x.toInt())
|
18
|
-
a == x; // -> error
|
19
|
-
a.toInt() == x.toInt() // -> no error
|
20
|
-
*/
|
21
|
-
|
22
|
-
// bytes5 allows for chain ids up to 13 digits
|
23
|
-
type TypeA is uint248;
|
24
|
-
|
25
|
-
// type bindings
|
26
|
-
using {
|
27
|
-
eqTypeA as ==,
|
28
|
-
neTypeA as !=,
|
29
|
-
TypeALib.toInt
|
30
|
-
} for TypeA global;
|
31
|
-
|
32
|
-
// general pure free functions
|
33
|
-
function toTypeA(uint256 typeA) pure returns(TypeA) { return TypeA.wrap(uint248(typeA)); }
|
34
|
-
|
35
|
-
// pure free functions for operators
|
36
|
-
function eqTypeA(TypeA a, TypeA b) pure returns(bool isSame) { return TypeA.unwrap(a) == TypeA.unwrap(b); }
|
37
|
-
function neTypeA(TypeA a, TypeA b) pure returns(bool isDifferent) { return TypeA.unwrap(a) != TypeA.unwrap(b); }
|
38
|
-
|
39
|
-
// library functions that operate on user defined type
|
40
|
-
library TypeALib {
|
41
|
-
function toInt(TypeA typeA) internal pure returns(uint256) { return uint256(TypeA.unwrap(typeA)); }
|
42
|
-
}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
// bytes5 allows for chain ids up to 13 digits
|
5
|
-
type TypeB is uint248;
|
6
|
-
|
7
|
-
// type bindings
|
8
|
-
using {
|
9
|
-
eqTypeB as ==,
|
10
|
-
addTypeB as +,
|
11
|
-
TypeBLib.toInt
|
12
|
-
} for TypeB global;
|
13
|
-
|
14
|
-
// general pure free functions
|
15
|
-
function toTypeB(uint256 x) pure returns(TypeB) { return TypeB.wrap(uint248(x)); }
|
16
|
-
|
17
|
-
// pure free functions for operators
|
18
|
-
function eqTypeB(TypeB a, TypeB b) pure returns(bool isSame) { return TypeB.unwrap(a) == TypeB.unwrap(b); }
|
19
|
-
function addTypeB(TypeB a, TypeB b) pure returns(TypeB sum) { return TypeB.wrap(TypeB.unwrap(a) + TypeB.unwrap(b)); }
|
20
|
-
|
21
|
-
// library functions that operate on user defined type
|
22
|
-
library TypeBLib {
|
23
|
-
function toInt(TypeB b) internal pure returns(uint256) { return uint256(TypeB.unwrap(b)); }
|
24
|
-
}
|
@@ -1,218 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
// role admin handling of oz doesn't fit nft ownability
|
5
|
-
// import {AccessControlEnumerable} from "@openzeppelin/contracts/access/AccessControlEnumerable.sol";
|
6
|
-
import "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
7
|
-
|
8
|
-
import {IAccessModule} from "./IAccess.sol";
|
9
|
-
|
10
|
-
|
11
|
-
abstract contract AccessModule is
|
12
|
-
IAccessModule
|
13
|
-
{
|
14
|
-
string constant public PRODUCT_OWNER = "ProductOwner";
|
15
|
-
string constant public ORACLE_OWNER = "OracleOwner";
|
16
|
-
string constant public POOL_OWNER = "PoolOwner";
|
17
|
-
|
18
|
-
using EnumerableSet for EnumerableSet.AddressSet;
|
19
|
-
|
20
|
-
event LogAccessRoleGranted(bytes32 role, address member, bool isMember);
|
21
|
-
|
22
|
-
mapping(bytes32 role => RoleInfo info) private _info;
|
23
|
-
bytes32 [] private _roles;
|
24
|
-
|
25
|
-
bytes32 private immutable _productOwnerRole;
|
26
|
-
bytes32 private immutable _oracleOwnerRole;
|
27
|
-
bytes32 private immutable _poolOwnerRole;
|
28
|
-
|
29
|
-
mapping(bytes32 role => mapping(address member => bool isMember)) private _isRoleMember;
|
30
|
-
mapping(bytes32 role => EnumerableSet.AddressSet) private _roleMembers;
|
31
|
-
|
32
|
-
modifier onlyOwner() {
|
33
|
-
require(msg.sender == this.getOwner(), "ERROR:ACM-001:NOT_OWNER");
|
34
|
-
_;
|
35
|
-
}
|
36
|
-
|
37
|
-
constructor() {
|
38
|
-
_productOwnerRole = _createRole(PRODUCT_OWNER);
|
39
|
-
_oracleOwnerRole = _createRole(ORACLE_OWNER);
|
40
|
-
_poolOwnerRole = _createRole(POOL_OWNER);
|
41
|
-
}
|
42
|
-
|
43
|
-
function PRODUCT_OWNER_ROLE() public view override returns(bytes32 role) { return _productOwnerRole; }
|
44
|
-
function ORACLE_OWNER_ROLE() public view override returns(bytes32 role) { return _oracleOwnerRole; }
|
45
|
-
function POOL_OWNER_ROLE() public view override returns(bytes32 role) { return _poolOwnerRole; }
|
46
|
-
|
47
|
-
|
48
|
-
function createRole(string memory roleName)
|
49
|
-
external
|
50
|
-
override
|
51
|
-
onlyOwner
|
52
|
-
returns(bytes32 role)
|
53
|
-
{
|
54
|
-
return _createRole(roleName);
|
55
|
-
}
|
56
|
-
|
57
|
-
function _createRole(string memory roleName)
|
58
|
-
internal
|
59
|
-
returns(bytes32 role)
|
60
|
-
{
|
61
|
-
RoleInfo memory info = RoleInfo(
|
62
|
-
0,
|
63
|
-
roleName,
|
64
|
-
true
|
65
|
-
);
|
66
|
-
|
67
|
-
role = _setRoleInfo(info);
|
68
|
-
|
69
|
-
|
70
|
-
}
|
71
|
-
|
72
|
-
// TODO move to module
|
73
|
-
function disableRole(bytes32 role)
|
74
|
-
external
|
75
|
-
override
|
76
|
-
onlyOwner
|
77
|
-
{
|
78
|
-
RoleInfo memory info = _info[role];
|
79
|
-
require(info.id == role, "ERROR:AOS-001:ROLE_DOES_NOT_EXIST");
|
80
|
-
|
81
|
-
info.isActive = false;
|
82
|
-
_setRoleInfo(info);
|
83
|
-
|
84
|
-
|
85
|
-
}
|
86
|
-
|
87
|
-
// TODO move to module
|
88
|
-
function enableRole(bytes32 role)
|
89
|
-
external
|
90
|
-
override
|
91
|
-
onlyOwner
|
92
|
-
{
|
93
|
-
RoleInfo memory info = _info[role];
|
94
|
-
require(info.id == role, "ERROR:AOS-002:ROLE_DOES_NOT_EXIST");
|
95
|
-
|
96
|
-
info.isActive = true;
|
97
|
-
_setRoleInfo(info);
|
98
|
-
|
99
|
-
|
100
|
-
}
|
101
|
-
|
102
|
-
function grantRole(bytes32 role, address member)
|
103
|
-
external
|
104
|
-
override
|
105
|
-
onlyOwner
|
106
|
-
{
|
107
|
-
require(_info[role].id == role, "ERROR:ACM-010:ROLE_NOT_EXISTING");
|
108
|
-
require(_info[role].isActive, "ERROR:ACM-011:ROLE_NOT_ACTIVE");
|
109
|
-
|
110
|
-
_isRoleMember[role][member] = true;
|
111
|
-
_roleMembers[role].add(member);
|
112
|
-
|
113
|
-
emit LogAccessRoleGranted(role, member, _isRoleMember[role][member]);
|
114
|
-
}
|
115
|
-
|
116
|
-
|
117
|
-
function revokeRole(bytes32 role, address member)
|
118
|
-
external
|
119
|
-
override
|
120
|
-
onlyOwner
|
121
|
-
{
|
122
|
-
require(_info[role].id == role, "ERROR:ACM-020:ROLE_NOT_EXISTING");
|
123
|
-
|
124
|
-
_isRoleMember[role][member] = false;
|
125
|
-
_roleMembers[role].remove(member);
|
126
|
-
|
127
|
-
|
128
|
-
}
|
129
|
-
|
130
|
-
|
131
|
-
function hasRole(bytes32 role, address member)
|
132
|
-
external
|
133
|
-
view
|
134
|
-
override
|
135
|
-
returns(bool)
|
136
|
-
{
|
137
|
-
return _isRoleMember[role][member];
|
138
|
-
}
|
139
|
-
|
140
|
-
|
141
|
-
function getRoleInfo(bytes32 role)
|
142
|
-
external
|
143
|
-
override
|
144
|
-
view
|
145
|
-
returns(RoleInfo memory info)
|
146
|
-
{
|
147
|
-
return _info[role];
|
148
|
-
}
|
149
|
-
|
150
|
-
|
151
|
-
function getRole(uint256 idx)
|
152
|
-
external
|
153
|
-
override
|
154
|
-
view
|
155
|
-
returns(bytes32 role)
|
156
|
-
{
|
157
|
-
return _roles[idx];
|
158
|
-
}
|
159
|
-
|
160
|
-
|
161
|
-
function getRoleCount()
|
162
|
-
external
|
163
|
-
override
|
164
|
-
view
|
165
|
-
returns(uint256 roles)
|
166
|
-
{
|
167
|
-
return _roles.length;
|
168
|
-
}
|
169
|
-
|
170
|
-
function getRoleMemberCount(bytes32 role)
|
171
|
-
public
|
172
|
-
override
|
173
|
-
view
|
174
|
-
returns(uint256 roleMembers)
|
175
|
-
{
|
176
|
-
return _roleMembers[role].length();
|
177
|
-
}
|
178
|
-
|
179
|
-
function getRoleMember(bytes32 role, uint256 idx)
|
180
|
-
public
|
181
|
-
override
|
182
|
-
view
|
183
|
-
returns(address roleMembers)
|
184
|
-
{
|
185
|
-
return _roleMembers[role].at(idx);
|
186
|
-
}
|
187
|
-
|
188
|
-
function getRoleForName(string memory roleName)
|
189
|
-
public
|
190
|
-
override
|
191
|
-
pure
|
192
|
-
returns(bytes32 role)
|
193
|
-
{
|
194
|
-
return keccak256(abi.encode(roleName));
|
195
|
-
}
|
196
|
-
|
197
|
-
|
198
|
-
function _setRoleInfo(RoleInfo memory info)
|
199
|
-
internal
|
200
|
-
returns(bytes32 role)
|
201
|
-
{
|
202
|
-
role = info.id;
|
203
|
-
|
204
|
-
if(role == bytes32(0)) {
|
205
|
-
role = getRoleForName(info.name);
|
206
|
-
// TODO check that this is a new role id
|
207
|
-
|
208
|
-
info.id = role;
|
209
|
-
_roles.push(role);
|
210
|
-
|
211
|
-
|
212
|
-
}
|
213
|
-
|
214
|
-
_info[role] = info;
|
215
|
-
|
216
|
-
|
217
|
-
}
|
218
|
-
}
|
@@ -1,83 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IOwnable, IRegistryLinked} from "../../registry/IRegistry.sol";
|
5
|
-
|
6
|
-
interface IAccess {
|
7
|
-
|
8
|
-
struct RoleInfo {
|
9
|
-
bytes32 id;
|
10
|
-
string name;
|
11
|
-
bool isActive;
|
12
|
-
}
|
13
|
-
}
|
14
|
-
|
15
|
-
interface IAccessCheckRole {
|
16
|
-
|
17
|
-
function hasRole(bytes32 role, address member)
|
18
|
-
external
|
19
|
-
view
|
20
|
-
returns(bool);
|
21
|
-
}
|
22
|
-
|
23
|
-
interface IAccessComponentTypeRoles {
|
24
|
-
function PRODUCT_OWNER_ROLE() external view returns(bytes32 role);
|
25
|
-
function ORACLE_OWNER_ROLE() external view returns(bytes32 role);
|
26
|
-
function POOL_OWNER_ROLE() external view returns(bytes32 role);
|
27
|
-
}
|
28
|
-
|
29
|
-
|
30
|
-
interface IAccessModule is
|
31
|
-
IOwnable,
|
32
|
-
IRegistryLinked,
|
33
|
-
IAccess,
|
34
|
-
IAccessComponentTypeRoles,
|
35
|
-
IAccessCheckRole
|
36
|
-
{
|
37
|
-
|
38
|
-
function createRole(string memory roleName)
|
39
|
-
external
|
40
|
-
returns(bytes32 role);
|
41
|
-
|
42
|
-
function enableRole(bytes32 role)
|
43
|
-
external;
|
44
|
-
|
45
|
-
function disableRole(bytes32 role)
|
46
|
-
external;
|
47
|
-
|
48
|
-
function grantRole(bytes32 role, address member)
|
49
|
-
external;
|
50
|
-
|
51
|
-
function revokeRole(bytes32 role, address member)
|
52
|
-
external;
|
53
|
-
|
54
|
-
function getRole(uint256 idx)
|
55
|
-
external
|
56
|
-
view
|
57
|
-
returns(bytes32 role);
|
58
|
-
|
59
|
-
function getRoleInfo(bytes32 role)
|
60
|
-
external
|
61
|
-
view
|
62
|
-
returns(RoleInfo memory info);
|
63
|
-
|
64
|
-
function getRoleForName(string memory roleName)
|
65
|
-
external
|
66
|
-
pure
|
67
|
-
returns(bytes32 role);
|
68
|
-
|
69
|
-
function getRoleCount()
|
70
|
-
external
|
71
|
-
view
|
72
|
-
returns(uint256 roles);
|
73
|
-
|
74
|
-
function getRoleMemberCount(bytes32 role)
|
75
|
-
external
|
76
|
-
view
|
77
|
-
returns(uint256 roleMembers);
|
78
|
-
|
79
|
-
function getRoleMember(bytes32 role, uint256 idx)
|
80
|
-
external
|
81
|
-
view
|
82
|
-
returns(address roleMembers);
|
83
|
-
}
|
@@ -1,248 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {RegistryLinked} from "../../registry/Registry.sol";
|
5
|
-
import {IRegistry, IRegistryLinked} from "../../registry/IRegistry.sol";
|
6
|
-
import {IAccessComponentTypeRoles, IAccessCheckRole} from "../access/IAccess.sol";
|
7
|
-
import {IInstance} from "../IInstance.sol";
|
8
|
-
|
9
|
-
import {IComponent, IComponentContract, IComponentModule, IComponentOwnerService} from "./IComponent.sol";
|
10
|
-
import {IProductComponent} from "../../components/IProduct.sol";
|
11
|
-
import {IPoolModule} from "../pool/IPoolModule.sol";
|
12
|
-
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
13
|
-
|
14
|
-
abstract contract ComponentModule is
|
15
|
-
IRegistryLinked,
|
16
|
-
IAccessComponentTypeRoles,
|
17
|
-
IAccessCheckRole,
|
18
|
-
IComponentModule
|
19
|
-
{
|
20
|
-
using NftIdLib for NftId;
|
21
|
-
|
22
|
-
mapping(NftId nftId => ComponentInfo info) private _componentInfo;
|
23
|
-
mapping(NftId nftId => NftId poolNftId) private _poolNftIdForProduct;
|
24
|
-
mapping(address cAddress => NftId nftId) private _nftIdByAddress;
|
25
|
-
NftId[] private _nftIds;
|
26
|
-
|
27
|
-
mapping(uint256 cType => bytes32 role) private _componentOwnerRole;
|
28
|
-
|
29
|
-
IComponentOwnerService private _componentOwnerService;
|
30
|
-
|
31
|
-
modifier onlyComponentOwnerService() {
|
32
|
-
require(address(_componentOwnerService) == msg.sender, "ERROR:CMP-001:NOT_OWNER_SERVICE");
|
33
|
-
_;
|
34
|
-
}
|
35
|
-
|
36
|
-
constructor(address componentOwnerService) {
|
37
|
-
_componentOwnerService = ComponentOwnerService(componentOwnerService);
|
38
|
-
}
|
39
|
-
|
40
|
-
function registerComponent(IComponentContract component)
|
41
|
-
external
|
42
|
-
override
|
43
|
-
onlyComponentOwnerService
|
44
|
-
returns(NftId nftId)
|
45
|
-
{
|
46
|
-
bytes32 typeRole = getRoleForType(component.getType());
|
47
|
-
require(
|
48
|
-
this.hasRole(typeRole, component.getInitialOwner()),
|
49
|
-
"ERROR:CMP-004:TYPE_ROLE_MISSING");
|
50
|
-
|
51
|
-
nftId = this.getRegistry().register(address(component));
|
52
|
-
|
53
|
-
_componentInfo[nftId] = ComponentInfo(
|
54
|
-
nftId,
|
55
|
-
CState.Active);
|
56
|
-
|
57
|
-
// special case product -> persist product - pool assignment
|
58
|
-
if(component.getType() == this.getRegistry().PRODUCT()) {
|
59
|
-
IProductComponent product = IProductComponent(address(component));
|
60
|
-
NftId poolNftId = product.getPoolNftId();
|
61
|
-
require(poolNftId.gtz(), "ERROR:CMP-005:POOL_UNKNOWN");
|
62
|
-
// add more validation (type, token, ...)
|
63
|
-
|
64
|
-
_poolNftIdForProduct[nftId] = poolNftId;
|
65
|
-
|
66
|
-
// add creation of productInfo
|
67
|
-
}
|
68
|
-
else if(component.getType() == this.getRegistry().POOL()) {
|
69
|
-
IPoolModule poolModule = IPoolModule(address(this));
|
70
|
-
poolModule.createPoolInfo(
|
71
|
-
nftId,
|
72
|
-
address(component), // set pool as its wallet
|
73
|
-
address(0) // don't deal with token yet
|
74
|
-
);
|
75
|
-
}
|
76
|
-
|
77
|
-
_nftIdByAddress[address(component)] = nftId;
|
78
|
-
_nftIds.push(nftId);
|
79
|
-
|
80
|
-
// add logging
|
81
|
-
}
|
82
|
-
|
83
|
-
function getPoolNftId(NftId productNftId)
|
84
|
-
external
|
85
|
-
view
|
86
|
-
override
|
87
|
-
returns(NftId poolNftId)
|
88
|
-
{
|
89
|
-
poolNftId = _poolNftIdForProduct[productNftId];
|
90
|
-
}
|
91
|
-
|
92
|
-
|
93
|
-
function getComponentOwnerService()
|
94
|
-
external
|
95
|
-
override
|
96
|
-
view
|
97
|
-
returns(IComponentOwnerService)
|
98
|
-
{
|
99
|
-
return _componentOwnerService;
|
100
|
-
}
|
101
|
-
|
102
|
-
function setComponentInfo(ComponentInfo memory info)
|
103
|
-
external
|
104
|
-
onlyComponentOwnerService
|
105
|
-
returns(NftId nftId)
|
106
|
-
{
|
107
|
-
nftId = info.nftId;
|
108
|
-
require(
|
109
|
-
nftId.gtz() && _componentInfo[nftId].nftId.eq(nftId),
|
110
|
-
"ERROR:CMP-006:COMPONENT_UNKNOWN");
|
111
|
-
|
112
|
-
_componentInfo[nftId] = info;
|
113
|
-
|
114
|
-
// add logging
|
115
|
-
}
|
116
|
-
|
117
|
-
function getComponentInfo(NftId nftId)
|
118
|
-
external
|
119
|
-
override
|
120
|
-
view
|
121
|
-
returns(ComponentInfo memory)
|
122
|
-
{
|
123
|
-
return _componentInfo[nftId];
|
124
|
-
}
|
125
|
-
|
126
|
-
function getComponentOwner(NftId nftId)
|
127
|
-
external
|
128
|
-
view
|
129
|
-
returns(address owner)
|
130
|
-
{
|
131
|
-
|
132
|
-
}
|
133
|
-
|
134
|
-
function getComponentId(address componentAddress)
|
135
|
-
external
|
136
|
-
view
|
137
|
-
returns(NftId componentNftId)
|
138
|
-
{
|
139
|
-
return _nftIdByAddress[componentAddress];
|
140
|
-
}
|
141
|
-
|
142
|
-
|
143
|
-
function getComponentId(uint256 idx)
|
144
|
-
external
|
145
|
-
override
|
146
|
-
view
|
147
|
-
returns(NftId componentNftId)
|
148
|
-
{
|
149
|
-
return _nftIds[idx];
|
150
|
-
}
|
151
|
-
|
152
|
-
|
153
|
-
function components()
|
154
|
-
external
|
155
|
-
override
|
156
|
-
view
|
157
|
-
returns(uint256 numberOfCompnents)
|
158
|
-
{
|
159
|
-
return _nftIds.length;
|
160
|
-
}
|
161
|
-
|
162
|
-
function getRoleForType(uint256 cType)
|
163
|
-
public
|
164
|
-
view
|
165
|
-
returns(bytes32 role)
|
166
|
-
{
|
167
|
-
if(cType == this.getRegistry().PRODUCT()) {
|
168
|
-
return this.PRODUCT_OWNER_ROLE();
|
169
|
-
}
|
170
|
-
if(cType == this.getRegistry().POOL()) {
|
171
|
-
return this.POOL_OWNER_ROLE();
|
172
|
-
}
|
173
|
-
if(cType == this.getRegistry().ORACLE()) {
|
174
|
-
return this.ORACLE_OWNER_ROLE();
|
175
|
-
}
|
176
|
-
|
177
|
-
}
|
178
|
-
}
|
179
|
-
|
180
|
-
|
181
|
-
// this is actually the component owner service
|
182
|
-
contract ComponentOwnerService is
|
183
|
-
RegistryLinked,
|
184
|
-
IComponent,
|
185
|
-
IComponentOwnerService
|
186
|
-
{
|
187
|
-
using NftIdLib for NftId;
|
188
|
-
|
189
|
-
modifier onlyComponentOwner(IComponentContract component) {
|
190
|
-
NftId nftId = _registry.getNftId(address(component));
|
191
|
-
require(
|
192
|
-
nftId.gtz(),
|
193
|
-
"ERROR:COS-001:COMPONENT_UNKNOWN");
|
194
|
-
require(
|
195
|
-
msg.sender == _registry.getOwner(nftId),
|
196
|
-
"ERROR:COS-002:NOT_OWNER"
|
197
|
-
);
|
198
|
-
_;
|
199
|
-
}
|
200
|
-
|
201
|
-
constructor(address registry)
|
202
|
-
RegistryLinked(registry)
|
203
|
-
{ }
|
204
|
-
|
205
|
-
function register(IComponentContract component)
|
206
|
-
external
|
207
|
-
override
|
208
|
-
returns(NftId nftId)
|
209
|
-
{
|
210
|
-
require(
|
211
|
-
msg.sender == component.getInitialOwner(),
|
212
|
-
"ERROR:COS-003:NOT_OWNER");
|
213
|
-
|
214
|
-
IInstance instance = component.getInstance();
|
215
|
-
nftId = instance.registerComponent(component);
|
216
|
-
}
|
217
|
-
|
218
|
-
|
219
|
-
function lock(IComponentContract component)
|
220
|
-
external
|
221
|
-
override
|
222
|
-
onlyComponentOwner(component)
|
223
|
-
{
|
224
|
-
IInstance instance = component.getInstance();
|
225
|
-
ComponentInfo memory info = instance.getComponentInfo(component.getNftId());
|
226
|
-
require(info.nftId.gtz(), "ERROR_COMPONENT_UNKNOWN");
|
227
|
-
// TODO add state change validation
|
228
|
-
|
229
|
-
info.state = CState.Locked;
|
230
|
-
instance.setComponentInfo(info);
|
231
|
-
}
|
232
|
-
|
233
|
-
|
234
|
-
function unlock(IComponentContract component)
|
235
|
-
external
|
236
|
-
override
|
237
|
-
onlyComponentOwner(component)
|
238
|
-
{
|
239
|
-
IInstance instance = component.getInstance();
|
240
|
-
ComponentInfo memory info = instance.getComponentInfo(component.getNftId());
|
241
|
-
require(info.nftId.gtz(), "ERROR_COMPONENT_UNKNOWN");
|
242
|
-
// TODO state change validation
|
243
|
-
|
244
|
-
info.state = CState.Active;
|
245
|
-
instance.setComponentInfo(info);
|
246
|
-
}
|
247
|
-
|
248
|
-
}
|