@etherisc/gif-next 0.0.2-fca9315-260 → 0.0.2-fd4931b-974
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 +8 -13
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1410 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1343 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +799 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Pool.sol/Pool.json → distribution/IDistributionComponent.sol/IDistributionComponent.json} +366 -367
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +808 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +68 -54
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +267 -1594
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +285 -211
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +412 -2526
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +480 -166
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +132 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +610 -421
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +438 -399
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +348 -106
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3468 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +58 -75
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{ISetup.sol/ISetup.json → IComponents.sol/IComponents.json} +2 -2
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1091 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +723 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +257 -288
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +565 -186
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1044 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1559 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1411 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +719 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +820 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +699 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1264 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +787 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IApplicationService.sol/IApplicationService.json} +211 -212
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +237 -302
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +530 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +351 -311
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IDistributionService.sol/IDistributionService.json → product/IProductService.sol/IProductService.json} +112 -172
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1132 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +731 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +969 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +755 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → product/Product.sol/Product.json} +857 -214
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +673 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +675 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +158 -13
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +337 -225
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +277 -30
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +74 -61
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +465 -267
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +334 -93
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +634 -69
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +448 -50
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components/Distribution.sol/Distribution.json → shared/Component.sol/Component.json} +321 -280
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1461 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +765 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +215 -226
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/IDistributionComponent.sol/IDistributionComponent.json → shared/IComponent.sol/IComponent.json} +205 -228
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +854 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Component.sol/Component.json → shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json} +203 -160
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +27 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -29
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +71 -160
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1030 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +581 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +314 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +102 -35
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +310 -74
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +125 -60
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +172 -160
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1770 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → staking/IStakingService.sol/IStakingService.json} +261 -238
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2500 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +844 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +263 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +960 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +694 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +308 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +16 -3
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +185 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +148 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/distribution/Distribution.sol +263 -0
- package/contracts/distribution/DistributionService.sol +298 -0
- package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +15 -12
- package/contracts/distribution/IDistributionComponent.sol +66 -0
- package/contracts/distribution/IDistributionService.sol +81 -0
- package/contracts/instance/BundleManager.sol +15 -14
- package/contracts/instance/IInstance.sol +49 -44
- package/contracts/instance/IInstanceService.sol +57 -15
- package/contracts/instance/Instance.sol +138 -179
- package/contracts/instance/InstanceAccessManager.sol +406 -161
- package/contracts/instance/InstanceAuthorizationsLib.sol +336 -0
- package/contracts/instance/InstanceReader.sol +135 -62
- package/contracts/instance/InstanceService.sol +240 -305
- package/contracts/instance/InstanceServiceManager.sol +12 -22
- package/contracts/instance/InstanceStore.sol +260 -0
- package/contracts/instance/base/BalanceStore.sol +118 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +12 -14
- package/contracts/instance/module/IAccess.sol +24 -18
- package/contracts/instance/module/IBundle.sol +8 -8
- package/contracts/instance/module/IComponents.sol +52 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +56 -17
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
- package/contracts/pool/BundleService.sol +296 -0
- package/contracts/pool/BundleServiceManager.sol +42 -0
- package/contracts/pool/IBundleService.sol +106 -0
- package/contracts/pool/IPoolComponent.sol +112 -0
- package/contracts/pool/IPoolService.sol +147 -0
- package/contracts/pool/Pool.sol +299 -0
- package/contracts/pool/PoolService.sol +424 -0
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +254 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/ClaimService.sol +437 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +78 -0
- package/contracts/product/IPricingService.sol +39 -0
- package/contracts/product/IProductComponent.sol +42 -0
- package/contracts/product/IProductService.sol +33 -0
- package/contracts/product/PolicyService.sol +473 -0
- package/contracts/product/PolicyServiceManager.sol +42 -0
- package/contracts/product/PricingService.sol +301 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/product/Product.sol +377 -0
- package/contracts/product/ProductService.sol +124 -0
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/ChainNft.sol +15 -1
- package/contracts/registry/IRegistry.sol +38 -18
- package/contracts/registry/IRegistryService.sol +41 -38
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +193 -82
- package/contracts/registry/RegistryAccessManager.sol +72 -121
- package/contracts/registry/RegistryService.sol +164 -98
- package/contracts/registry/RegistryServiceManager.sol +28 -18
- package/contracts/registry/ReleaseManager.sol +390 -192
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +263 -56
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/Component.sol +286 -0
- package/contracts/shared/ComponentService.sol +595 -0
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +111 -0
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/IComponent.sol +74 -0
- package/contracts/shared/IComponentService.sol +91 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +14 -10
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +12 -11
- package/contracts/shared/IPolicyHolder.sol +45 -0
- package/contracts/shared/IRegisterable.sol +3 -3
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/InstanceLinkedComponent.sol +145 -0
- package/contracts/shared/KeyValueStore.sol +130 -0
- package/contracts/{instance/base → shared}/Lifecycle.sol +28 -7
- package/contracts/shared/NftIdSetManager.sol +69 -0
- package/contracts/shared/NftOwnable.sol +64 -85
- package/contracts/shared/PolicyHolder.sol +101 -0
- package/contracts/shared/ProxyManager.sol +126 -25
- package/contracts/shared/Registerable.sol +19 -30
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +37 -20
- package/contracts/shared/TokenHandler.sol +37 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/staking/IStaking.sol +113 -0
- package/contracts/staking/IStakingService.sol +122 -0
- package/contracts/staking/Staking.sol +348 -0
- package/contracts/staking/StakingManager.sol +52 -0
- package/contracts/staking/StakingReader.sol +92 -0
- package/contracts/staking/StakingService.sol +294 -0
- package/contracts/staking/StakingServiceManager.sol +44 -0
- package/contracts/staking/TargetManagerLib.sol +141 -0
- package/contracts/type/Amount.sol +114 -0
- package/contracts/{types → type}/Blocknumber.sol +7 -1
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/DistributorType.sol +2 -2
- package/contracts/{types → type}/Fee.sol +32 -22
- package/contracts/{types → type}/NftId.sol +17 -11
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +26 -9
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/type/RoleId.sol +143 -0
- package/contracts/type/Seconds.sol +63 -0
- package/contracts/{types → type}/StateId.sol +24 -6
- package/contracts/{types → type}/Timestamp.sol +18 -13
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +0 -455
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- 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/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/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- 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/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1102
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -449
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -772
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -437
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1227
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -505
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -806
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -437
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -856
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -437
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -313
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -608
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/Component.sol +0 -216
- package/contracts/components/Distribution.sol +0 -150
- package/contracts/components/IComponent.sol +0 -43
- package/contracts/components/IDistributionComponent.sol +0 -47
- package/contracts/components/IPoolComponent.sol +0 -60
- package/contracts/components/IProductComponent.sol +0 -39
- package/contracts/components/Pool.sol +0 -227
- package/contracts/components/Product.sol +0 -265
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/base/ComponentService.sol +0 -134
- package/contracts/instance/base/KeyValueStore.sol +0 -172
- package/contracts/instance/module/ISetup.sol +0 -46
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/instance/service/BundleService.sol +0 -293
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/DistributionService.sol +0 -106
- package/contracts/instance/service/IBundleService.sol +0 -44
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -94
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/IProductService.sol +0 -40
- package/contracts/instance/service/PolicyService.sol +0 -538
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -110
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -234
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- package/contracts/types/RoleId.sol +0 -90
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -0,0 +1,336 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, DISTRIBUTION_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, INSTANCE_SERVICE_ROLE, COMPONENT_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, APPLICATION_SERVICE_ROLE, POLICY_SERVICE_ROLE, CLAIM_SERVICE_ROLE, BUNDLE_SERVICE_ROLE, INSTANCE_ROLE} from "../type/RoleId.sol";
|
5
|
+
import {APPLICATION, BUNDLE, CLAIM, COMPONENT, DISTRIBUTION, INSTANCE, POLICY, POOL, PRODUCT, REGISTRY} from "../type/ObjectType.sol";
|
6
|
+
import {VersionPart} from "../type/Version.sol";
|
7
|
+
|
8
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
9
|
+
|
10
|
+
import {Instance} from "./Instance.sol";
|
11
|
+
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
12
|
+
import {InstanceReader} from "./InstanceReader.sol";
|
13
|
+
import {BundleManager} from "./BundleManager.sol";
|
14
|
+
import {AccessManagerUpgradeableInitializeable} from "../shared/AccessManagerUpgradeableInitializeable.sol";
|
15
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
16
|
+
|
17
|
+
|
18
|
+
library InstanceAuthorizationsLib
|
19
|
+
{
|
20
|
+
function grantInitialAuthorizations(
|
21
|
+
InstanceAccessManager clonedAccessManager,
|
22
|
+
Instance clonedInstance,
|
23
|
+
BundleManager clonedBundleManager,
|
24
|
+
InstanceStore clonedInstanceStore,
|
25
|
+
address instanceOwner,
|
26
|
+
IRegistry registry,
|
27
|
+
VersionPart majorVersion)
|
28
|
+
external
|
29
|
+
{
|
30
|
+
_createCoreAndGifRoles(clonedAccessManager);
|
31
|
+
_createCoreTargets(clonedAccessManager, clonedInstance, clonedBundleManager, clonedInstanceStore);
|
32
|
+
_grantComponentServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
33
|
+
_grantDistributionServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
34
|
+
_grantPoolServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
35
|
+
_grantProductServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
36
|
+
_grantApplicationServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
37
|
+
_grantPolicyServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
38
|
+
_grantClaimServiceAuthorizations(clonedAccessManager, clonedInstanceStore, registry, majorVersion);
|
39
|
+
_grantBundleServiceAuthorizations(clonedAccessManager, clonedInstanceStore, clonedBundleManager, registry, majorVersion);
|
40
|
+
_grantInstanceServiceAuthorizations(clonedAccessManager, clonedInstance, registry, majorVersion);
|
41
|
+
_grantInstanceAuthorizations(clonedAccessManager, registry, majorVersion);
|
42
|
+
_grantInstanceOwnerAuthorizations(clonedAccessManager, clonedInstance, registry, majorVersion);
|
43
|
+
}
|
44
|
+
|
45
|
+
function _createCoreAndGifRoles(InstanceAccessManager clonedAccessManager) private {
|
46
|
+
// default roles controlled by ADMIN_ROLE -> core roles
|
47
|
+
// all set/granted only once during cloning (the only exception is INSTANCE_OWNER_ROLE, hooked to instance nft)
|
48
|
+
clonedAccessManager.createCoreRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole");
|
49
|
+
clonedAccessManager.createCoreRole(COMPONENT_SERVICE_ROLE(), "ComponentServiceRole");
|
50
|
+
clonedAccessManager.createCoreRole(DISTRIBUTION_SERVICE_ROLE(), "DistributionServiceRole");
|
51
|
+
clonedAccessManager.createCoreRole(POOL_SERVICE_ROLE(), "PoolServiceRole");
|
52
|
+
clonedAccessManager.createCoreRole(APPLICATION_SERVICE_ROLE(), "ApplicationServiceRole");
|
53
|
+
clonedAccessManager.createCoreRole(PRODUCT_SERVICE_ROLE(), "ProductServiceRole");
|
54
|
+
clonedAccessManager.createCoreRole(CLAIM_SERVICE_ROLE(), "ClaimServiceRole");
|
55
|
+
clonedAccessManager.createCoreRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole");
|
56
|
+
clonedAccessManager.createCoreRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole");
|
57
|
+
|
58
|
+
// default roles controlled by INSTANCE_OWNER_ROLE -> gif roles
|
59
|
+
clonedAccessManager.createGifRole(DISTRIBUTION_OWNER_ROLE(), "DistributionOwnerRole", INSTANCE_OWNER_ROLE());
|
60
|
+
clonedAccessManager.createGifRole(POOL_OWNER_ROLE(), "PoolOwnerRole", INSTANCE_OWNER_ROLE());
|
61
|
+
clonedAccessManager.createGifRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole", INSTANCE_OWNER_ROLE());
|
62
|
+
}
|
63
|
+
|
64
|
+
function _createCoreTargets(
|
65
|
+
InstanceAccessManager clonedAccessManager,
|
66
|
+
Instance clonedInstance,
|
67
|
+
BundleManager clonedBundleManager,
|
68
|
+
InstanceStore clonedInstanceStore)
|
69
|
+
private
|
70
|
+
{
|
71
|
+
clonedAccessManager.createCoreTarget(address(clonedAccessManager), "InstanceAccessManager");// TODO create in instance access manager initializer?
|
72
|
+
clonedAccessManager.createCoreTarget(address(clonedInstance), "Instance");// TODO create in instance access manager initializer?
|
73
|
+
clonedAccessManager.createCoreTarget(address(clonedBundleManager), "BundleManager");
|
74
|
+
clonedAccessManager.createCoreTarget(address(clonedInstanceStore), "InstanceStore");
|
75
|
+
}
|
76
|
+
|
77
|
+
function _grantComponentServiceAuthorizations(
|
78
|
+
InstanceAccessManager clonedAccessManager,
|
79
|
+
InstanceStore clonedInstanceStore,
|
80
|
+
IRegistry registry,
|
81
|
+
VersionPart majorVersion)
|
82
|
+
private
|
83
|
+
{
|
84
|
+
// configure authorization for pool service on instance
|
85
|
+
address componentServiceAddress = registry.getServiceAddress(COMPONENT(), majorVersion);
|
86
|
+
clonedAccessManager.grantRole(COMPONENT_SERVICE_ROLE(), address(componentServiceAddress));
|
87
|
+
|
88
|
+
bytes4[] memory serviceSelectors = new bytes4[](8);
|
89
|
+
serviceSelectors[0] = clonedInstanceStore.createComponent.selector;
|
90
|
+
serviceSelectors[1] = clonedInstanceStore.updateComponent.selector;
|
91
|
+
serviceSelectors[2] = clonedInstanceStore.createPool.selector;
|
92
|
+
serviceSelectors[3] = clonedInstanceStore.createProduct.selector;
|
93
|
+
serviceSelectors[5] = clonedInstanceStore.updateProduct.selector;
|
94
|
+
serviceSelectors[6] = clonedInstanceStore.increaseBalance.selector;
|
95
|
+
serviceSelectors[7] = clonedInstanceStore.increaseFees.selector;
|
96
|
+
|
97
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
98
|
+
"InstanceStore",
|
99
|
+
serviceSelectors,
|
100
|
+
COMPONENT_SERVICE_ROLE());
|
101
|
+
}
|
102
|
+
|
103
|
+
function _grantDistributionServiceAuthorizations(
|
104
|
+
InstanceAccessManager clonedAccessManager,
|
105
|
+
InstanceStore clonedInstanceStore,
|
106
|
+
IRegistry registry,
|
107
|
+
VersionPart majorVersion)
|
108
|
+
private
|
109
|
+
{
|
110
|
+
// configure authorization for distribution service on instance
|
111
|
+
address distributionServiceAddress = registry.getServiceAddress(DISTRIBUTION(), majorVersion);
|
112
|
+
clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE(), distributionServiceAddress);
|
113
|
+
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](9);
|
114
|
+
// instanceDistributionServiceSelectors[0] = clonedInstanceStore.createDistributionSetup.selector;
|
115
|
+
// instanceDistributionServiceSelectors[0] = clonedInstanceStore.updateDistributionSetup.selector;
|
116
|
+
instanceDistributionServiceSelectors[0] = clonedInstanceStore.createDistributorType.selector;
|
117
|
+
instanceDistributionServiceSelectors[1] = clonedInstanceStore.updateDistributorType.selector;
|
118
|
+
instanceDistributionServiceSelectors[2] = clonedInstanceStore.updateDistributorTypeState.selector;
|
119
|
+
instanceDistributionServiceSelectors[3] = clonedInstanceStore.createDistributor.selector;
|
120
|
+
instanceDistributionServiceSelectors[4] = clonedInstanceStore.updateDistributor.selector;
|
121
|
+
instanceDistributionServiceSelectors[5] = clonedInstanceStore.updateDistributorState.selector;
|
122
|
+
instanceDistributionServiceSelectors[6] = clonedInstanceStore.createReferral.selector;
|
123
|
+
instanceDistributionServiceSelectors[7] = clonedInstanceStore.updateReferral.selector;
|
124
|
+
instanceDistributionServiceSelectors[8] = clonedInstanceStore.updateReferralState.selector;
|
125
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
126
|
+
"InstanceStore",
|
127
|
+
instanceDistributionServiceSelectors,
|
128
|
+
DISTRIBUTION_SERVICE_ROLE());
|
129
|
+
}
|
130
|
+
|
131
|
+
function _grantPoolServiceAuthorizations(
|
132
|
+
InstanceAccessManager clonedAccessManager,
|
133
|
+
InstanceStore clonedInstanceStore,
|
134
|
+
IRegistry registry,
|
135
|
+
VersionPart majorVersion)
|
136
|
+
private
|
137
|
+
{
|
138
|
+
// configure authorization for pool service on instance
|
139
|
+
address poolServiceAddress = registry.getServiceAddress(POOL(), majorVersion);
|
140
|
+
clonedAccessManager.grantRole(POOL_SERVICE_ROLE(), address(poolServiceAddress));
|
141
|
+
bytes4[] memory instancePoolServiceSelectors = new bytes4[](1);
|
142
|
+
instancePoolServiceSelectors[0] = clonedInstanceStore.updatePool.selector;
|
143
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
144
|
+
"InstanceStore",
|
145
|
+
instancePoolServiceSelectors,
|
146
|
+
POOL_SERVICE_ROLE());
|
147
|
+
}
|
148
|
+
|
149
|
+
function _grantProductServiceAuthorizations(
|
150
|
+
InstanceAccessManager clonedAccessManager,
|
151
|
+
InstanceStore clonedInstanceStore,
|
152
|
+
IRegistry registry,
|
153
|
+
VersionPart majorVersion)
|
154
|
+
private
|
155
|
+
{
|
156
|
+
// configure authorization for product service on instance
|
157
|
+
address productServiceAddress = registry.getServiceAddress(PRODUCT(), majorVersion);
|
158
|
+
clonedAccessManager.grantRole(PRODUCT_SERVICE_ROLE(), address(productServiceAddress));
|
159
|
+
bytes4[] memory instanceProductServiceSelectors = new bytes4[](3);
|
160
|
+
instanceProductServiceSelectors[0] = clonedInstanceStore.createRisk.selector;
|
161
|
+
instanceProductServiceSelectors[1] = clonedInstanceStore.updateRisk.selector;
|
162
|
+
instanceProductServiceSelectors[2] = clonedInstanceStore.updateRiskState.selector;
|
163
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
164
|
+
"InstanceStore",
|
165
|
+
instanceProductServiceSelectors,
|
166
|
+
PRODUCT_SERVICE_ROLE());
|
167
|
+
}
|
168
|
+
|
169
|
+
function _grantApplicationServiceAuthorizations(
|
170
|
+
InstanceAccessManager clonedAccessManager,
|
171
|
+
InstanceStore clonedInstanceStore,
|
172
|
+
IRegistry registry,
|
173
|
+
VersionPart majorVersion)
|
174
|
+
private
|
175
|
+
{
|
176
|
+
// configure authorization for application services on instance
|
177
|
+
address applicationServiceAddress = registry.getServiceAddress(APPLICATION(), majorVersion);
|
178
|
+
clonedAccessManager.grantRole(APPLICATION_SERVICE_ROLE(), applicationServiceAddress);
|
179
|
+
bytes4[] memory instanceApplicationServiceSelectors = new bytes4[](3);
|
180
|
+
instanceApplicationServiceSelectors[0] = clonedInstanceStore.createApplication.selector;
|
181
|
+
instanceApplicationServiceSelectors[1] = clonedInstanceStore.updateApplication.selector;
|
182
|
+
instanceApplicationServiceSelectors[2] = clonedInstanceStore.updateApplicationState.selector;
|
183
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
184
|
+
"InstanceStore",
|
185
|
+
instanceApplicationServiceSelectors,
|
186
|
+
APPLICATION_SERVICE_ROLE());
|
187
|
+
}
|
188
|
+
|
189
|
+
function _grantPolicyServiceAuthorizations(
|
190
|
+
InstanceAccessManager clonedAccessManager,
|
191
|
+
InstanceStore clonedInstanceStore,
|
192
|
+
IRegistry registry,
|
193
|
+
VersionPart majorVersion)
|
194
|
+
private
|
195
|
+
{
|
196
|
+
// configure authorization for policy services on instance
|
197
|
+
address policyServiceAddress = registry.getServiceAddress(POLICY(), majorVersion);
|
198
|
+
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), policyServiceAddress);
|
199
|
+
bytes4[] memory instancePolicyServiceSelectors = new bytes4[](2);
|
200
|
+
instancePolicyServiceSelectors[0] = clonedInstanceStore.updatePolicy.selector;
|
201
|
+
instancePolicyServiceSelectors[1] = clonedInstanceStore.updatePolicyState.selector;
|
202
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
203
|
+
"InstanceStore",
|
204
|
+
instancePolicyServiceSelectors,
|
205
|
+
POLICY_SERVICE_ROLE());
|
206
|
+
}
|
207
|
+
|
208
|
+
function _grantClaimServiceAuthorizations(
|
209
|
+
InstanceAccessManager clonedAccessManager,
|
210
|
+
InstanceStore clonedInstanceStore,
|
211
|
+
IRegistry registry,
|
212
|
+
VersionPart majorVersion)
|
213
|
+
private
|
214
|
+
{
|
215
|
+
// configure authorization for claim/payout services on instance
|
216
|
+
address claimServiceAddress = registry.getServiceAddress(CLAIM(), majorVersion);
|
217
|
+
clonedAccessManager.grantRole(CLAIM_SERVICE_ROLE(), claimServiceAddress);
|
218
|
+
|
219
|
+
bytes4[] memory instancePolicyServiceSelectors = new bytes4[](1);
|
220
|
+
instancePolicyServiceSelectors[0] = clonedInstanceStore.updatePolicyClaims.selector;
|
221
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
222
|
+
"InstanceStore",
|
223
|
+
instancePolicyServiceSelectors,
|
224
|
+
CLAIM_SERVICE_ROLE());
|
225
|
+
|
226
|
+
bytes4[] memory instanceClaimServiceSelectors = new bytes4[](4);
|
227
|
+
instanceClaimServiceSelectors[0] = clonedInstanceStore.createClaim.selector;
|
228
|
+
instanceClaimServiceSelectors[1] = clonedInstanceStore.updateClaim.selector;
|
229
|
+
instanceClaimServiceSelectors[2] = clonedInstanceStore.createPayout.selector;
|
230
|
+
instanceClaimServiceSelectors[3] = clonedInstanceStore.updatePayout.selector;
|
231
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
232
|
+
"InstanceStore",
|
233
|
+
instanceClaimServiceSelectors,
|
234
|
+
CLAIM_SERVICE_ROLE());
|
235
|
+
}
|
236
|
+
|
237
|
+
function _grantBundleServiceAuthorizations(
|
238
|
+
InstanceAccessManager clonedAccessManager,
|
239
|
+
InstanceStore clonedInstanceStore,
|
240
|
+
BundleManager clonedBundleManager,
|
241
|
+
IRegistry registry,
|
242
|
+
VersionPart majorVersion)
|
243
|
+
private
|
244
|
+
{
|
245
|
+
// configure authorization for bundle service on instance
|
246
|
+
address bundleServiceAddress = registry.getServiceAddress(BUNDLE(), majorVersion);
|
247
|
+
clonedAccessManager.grantRole(BUNDLE_SERVICE_ROLE(), address(bundleServiceAddress));
|
248
|
+
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](5);
|
249
|
+
instanceBundleServiceSelectors[0] = clonedInstanceStore.createBundle.selector;
|
250
|
+
instanceBundleServiceSelectors[1] = clonedInstanceStore.updateBundle.selector;
|
251
|
+
instanceBundleServiceSelectors[2] = clonedInstanceStore.updateBundleState.selector;
|
252
|
+
instanceBundleServiceSelectors[3] = clonedInstanceStore.increaseLocked.selector;
|
253
|
+
instanceBundleServiceSelectors[4] = clonedInstanceStore.decreaseLocked.selector;
|
254
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
255
|
+
"InstanceStore",
|
256
|
+
instanceBundleServiceSelectors,
|
257
|
+
BUNDLE_SERVICE_ROLE());
|
258
|
+
|
259
|
+
// configure authorization for bundle service on bundle manager
|
260
|
+
bytes4[] memory bundleManagerBundleServiceSelectors = new bytes4[](5);
|
261
|
+
bundleManagerBundleServiceSelectors[0] = clonedBundleManager.linkPolicy.selector;
|
262
|
+
bundleManagerBundleServiceSelectors[1] = clonedBundleManager.unlinkPolicy.selector;
|
263
|
+
bundleManagerBundleServiceSelectors[2] = clonedBundleManager.add.selector;
|
264
|
+
bundleManagerBundleServiceSelectors[3] = clonedBundleManager.lock.selector;
|
265
|
+
bundleManagerBundleServiceSelectors[4] = clonedBundleManager.unlock.selector;
|
266
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
267
|
+
"BundleManager",
|
268
|
+
bundleManagerBundleServiceSelectors,
|
269
|
+
BUNDLE_SERVICE_ROLE());
|
270
|
+
}
|
271
|
+
|
272
|
+
function _grantInstanceServiceAuthorizations(
|
273
|
+
InstanceAccessManager clonedAccessManager,
|
274
|
+
Instance clonedInstance,
|
275
|
+
IRegistry registry,
|
276
|
+
VersionPart majorVersion)
|
277
|
+
private
|
278
|
+
{
|
279
|
+
// configure authorization for instance service on instance
|
280
|
+
address instanceServiceAddress = registry.getServiceAddress(INSTANCE(), majorVersion);
|
281
|
+
clonedAccessManager.grantRole(INSTANCE_SERVICE_ROLE(), instanceServiceAddress);
|
282
|
+
bytes4[] memory instanceInstanceServiceSelectors = new bytes4[](1);
|
283
|
+
instanceInstanceServiceSelectors[0] = clonedInstance.setInstanceReader.selector;
|
284
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
285
|
+
"Instance",
|
286
|
+
instanceInstanceServiceSelectors,
|
287
|
+
INSTANCE_SERVICE_ROLE());
|
288
|
+
|
289
|
+
// configure authorizations for instance service on instance access manager
|
290
|
+
bytes4[] memory accessManagerInstanceServiceSelectors = new bytes4[](3);
|
291
|
+
accessManagerInstanceServiceSelectors[0] = clonedAccessManager.createGifTarget.selector;
|
292
|
+
accessManagerInstanceServiceSelectors[1] = clonedAccessManager.setTargetLockedByService.selector;
|
293
|
+
accessManagerInstanceServiceSelectors[2] = clonedAccessManager.setCoreTargetFunctionRole.selector;
|
294
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
295
|
+
"InstanceAccessManager",
|
296
|
+
accessManagerInstanceServiceSelectors,
|
297
|
+
INSTANCE_SERVICE_ROLE());
|
298
|
+
}
|
299
|
+
|
300
|
+
function _grantInstanceAuthorizations(
|
301
|
+
InstanceAccessManager clonedAccessManager,
|
302
|
+
IRegistry registry,
|
303
|
+
VersionPart majorVersion)
|
304
|
+
private
|
305
|
+
{
|
306
|
+
bytes4[] memory accessManagerInstanceSelectors = new bytes4[](4);
|
307
|
+
accessManagerInstanceSelectors[0] = clonedAccessManager.createRole.selector;
|
308
|
+
accessManagerInstanceSelectors[1] = clonedAccessManager.createTarget.selector;
|
309
|
+
accessManagerInstanceSelectors[2] = clonedAccessManager.setTargetFunctionRole.selector;
|
310
|
+
accessManagerInstanceSelectors[3] = clonedAccessManager.setTargetLockedByInstance.selector;
|
311
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
312
|
+
"InstanceAccessManager",
|
313
|
+
accessManagerInstanceSelectors,
|
314
|
+
INSTANCE_ROLE());
|
315
|
+
}
|
316
|
+
|
317
|
+
function _grantInstanceOwnerAuthorizations(
|
318
|
+
InstanceAccessManager clonedAccessManager,
|
319
|
+
Instance clonedInstance,
|
320
|
+
IRegistry registry,
|
321
|
+
VersionPart majorVersion)
|
322
|
+
private
|
323
|
+
{
|
324
|
+
// configure authorization for instance owner on instance access manager
|
325
|
+
// instance owner role is granted/revoked ONLY by INSTANCE_ROLE
|
326
|
+
bytes4[] memory instanceInstanceOwnerSelectors = new bytes4[](4);
|
327
|
+
instanceInstanceOwnerSelectors[0] = clonedInstance.createRole.selector;
|
328
|
+
instanceInstanceOwnerSelectors[1] = clonedInstance.createTarget.selector;
|
329
|
+
instanceInstanceOwnerSelectors[2] = clonedInstance.setTargetFunctionRole.selector;
|
330
|
+
instanceInstanceOwnerSelectors[3] = clonedInstance.setTargetLocked.selector;
|
331
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
332
|
+
"Instance",
|
333
|
+
instanceInstanceOwnerSelectors,
|
334
|
+
INSTANCE_OWNER_ROLE());
|
335
|
+
}
|
336
|
+
}
|
@@ -3,49 +3,55 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
6
|
+
import {Amount} from "../type/Amount.sol";
|
7
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
8
|
+
import {DistributorType} from "../type/DistributorType.sol";
|
9
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
10
|
+
import {Key32} from "../type/Key32.sol";
|
11
|
+
import {NftId} from "../type/NftId.sol";
|
12
|
+
import {ObjectType, COMPONENT, DISTRIBUTOR, DISTRIBUTION, INSTANCE, PRODUCT, POLICY, POOL, FEE, BUNDLE} from "../type/ObjectType.sol";
|
13
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
14
|
+
import {ReferralId, ReferralStatus, ReferralLib, REFERRAL_OK, REFERRAL_ERROR_UNKNOWN, REFERRAL_ERROR_EXPIRED, REFERRAL_ERROR_EXHAUSTED} from "../type/Referral.sol";
|
12
15
|
import {Registerable} from "../shared/Registerable.sol";
|
13
|
-
import {RiskId} from "../
|
14
|
-
import {UFixed, MathLib, UFixedLib} from "../
|
15
|
-
import {Version} from "../
|
16
|
-
import {StateId} from "../
|
16
|
+
import {RiskId} from "../type/RiskId.sol";
|
17
|
+
import {UFixed, MathLib, UFixedLib} from "../type/UFixed.sol";
|
18
|
+
import {Version} from "../type/Version.sol";
|
19
|
+
import {StateId} from "../type/StateId.sol";
|
17
20
|
|
18
21
|
import {IRegistry} from "../registry/IRegistry.sol";
|
19
22
|
import {IBundle} from "../instance/module/IBundle.sol";
|
23
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
20
24
|
import {IDistribution} from "../instance/module/IDistribution.sol";
|
21
25
|
import {IInstance} from "./IInstance.sol";
|
22
|
-
import {IKeyValueStore} from "../
|
26
|
+
import {IKeyValueStore} from "../shared/IKeyValueStore.sol";
|
23
27
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
24
28
|
import {IRisk} from "../instance/module/IRisk.sol";
|
25
|
-
import {
|
26
|
-
|
27
|
-
import {
|
29
|
+
import {TimestampLib} from "../type/Timestamp.sol";
|
30
|
+
|
31
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
28
32
|
|
29
33
|
|
30
34
|
contract InstanceReader {
|
31
|
-
bool private _initialized;
|
32
35
|
|
33
|
-
|
34
|
-
|
35
|
-
IKeyValueStore internal _store;
|
36
|
+
error ErrorInstanceReaderAlreadyInitialized();
|
37
|
+
error ErrorInstanceReaderInstanceAddressZero();
|
36
38
|
|
37
|
-
|
38
|
-
require(!_initialized, "ERROR:CRD-000:ALREADY_INITIALIZED");
|
39
|
+
bool private _initialized;
|
39
40
|
|
40
|
-
|
41
|
-
|
42
|
-
"ERROR:CRD-001:REGISTRY_ZERO");
|
41
|
+
IInstance internal _instance;
|
42
|
+
InstanceStore internal _store;
|
43
43
|
|
44
|
+
function initialize(address instance) public {
|
45
|
+
if(_initialized) {
|
46
|
+
revert ErrorInstanceReaderAlreadyInitialized();
|
47
|
+
}
|
44
48
|
|
45
|
-
|
49
|
+
if(instance == address(0)) {
|
50
|
+
revert ErrorInstanceReaderInstanceAddressZero();
|
51
|
+
}
|
46
52
|
|
47
53
|
_instance = IInstance(instance);
|
48
|
-
_store =
|
54
|
+
_store = _instance.getInstanceStore();
|
49
55
|
|
50
56
|
_initialized = true;
|
51
57
|
}
|
@@ -69,7 +75,74 @@ contract InstanceReader {
|
|
69
75
|
view
|
70
76
|
returns (StateId state)
|
71
77
|
{
|
72
|
-
return
|
78
|
+
return _store.getState(toPolicyKey(policyNftId));
|
79
|
+
}
|
80
|
+
|
81
|
+
/// @dev returns true iff policy may be closed
|
82
|
+
/// a policy can be closed all conditions below are met
|
83
|
+
/// - policy exists
|
84
|
+
/// - has been activated
|
85
|
+
/// - is not yet closed
|
86
|
+
/// - has no open claims
|
87
|
+
/// - claim amount matches sum insured amount or is expired
|
88
|
+
function policyIsCloseable(NftId policyNftId)
|
89
|
+
public
|
90
|
+
view
|
91
|
+
returns (bool isCloseable)
|
92
|
+
{
|
93
|
+
IPolicy.PolicyInfo memory info = getPolicyInfo(policyNftId);
|
94
|
+
|
95
|
+
if (info.productNftId.eqz()) { return false; } // not closeable: policy does not exist (or does not belong to this instance)
|
96
|
+
if (info.activatedAt.eqz()) { return false; } // not closeable: not yet activated
|
97
|
+
if (info.closedAt.gtz()) { return false; } // not closeable: already closed
|
98
|
+
if (info.openClaimsCount > 0) { return false; } // not closeable: has open claims
|
99
|
+
|
100
|
+
// closeable: if sum of claims matches sum insured a policy may be closed prior to the expiry date
|
101
|
+
if (info.claimAmount == info.sumInsuredAmount) { return true; }
|
102
|
+
|
103
|
+
// not closeable: not yet expired
|
104
|
+
if (TimestampLib.blockTimestamp() < info.expiredAt) { return false; }
|
105
|
+
|
106
|
+
// all conditionsl to close the policy are met
|
107
|
+
return true;
|
108
|
+
}
|
109
|
+
|
110
|
+
function getClaimInfo(NftId policyNftId, ClaimId claimId)
|
111
|
+
public
|
112
|
+
view
|
113
|
+
returns (IPolicy.ClaimInfo memory info)
|
114
|
+
{
|
115
|
+
bytes memory data = _store.getData(claimId.toKey32(policyNftId));
|
116
|
+
if (data.length > 0) {
|
117
|
+
return abi.decode(data, (IPolicy.ClaimInfo));
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
function getClaimState(NftId policyNftId, ClaimId claimId)
|
122
|
+
public
|
123
|
+
view
|
124
|
+
returns (StateId state)
|
125
|
+
{
|
126
|
+
return _store.getState(claimId.toKey32(policyNftId));
|
127
|
+
}
|
128
|
+
|
129
|
+
function getPayoutInfo(NftId policyNftId, PayoutId payoutId)
|
130
|
+
public
|
131
|
+
view
|
132
|
+
returns (IPolicy.PayoutInfo memory info)
|
133
|
+
{
|
134
|
+
bytes memory data = _store.getData(payoutId.toKey32(policyNftId));
|
135
|
+
if (data.length > 0) {
|
136
|
+
return abi.decode(data, (IPolicy.PayoutInfo));
|
137
|
+
}
|
138
|
+
}
|
139
|
+
|
140
|
+
function getPayoutState(NftId policyNftId, PayoutId payoutId)
|
141
|
+
public
|
142
|
+
view
|
143
|
+
returns (StateId state)
|
144
|
+
{
|
145
|
+
return _store.getState(payoutId.toKey32(policyNftId));
|
73
146
|
}
|
74
147
|
|
75
148
|
function getRiskInfo(RiskId riskId)
|
@@ -83,30 +156,19 @@ contract InstanceReader {
|
|
83
156
|
}
|
84
157
|
}
|
85
158
|
|
86
|
-
function getTokenHandler(NftId
|
159
|
+
function getTokenHandler(NftId componentNftId)
|
87
160
|
public
|
88
161
|
view
|
89
162
|
returns (address tokenHandler)
|
90
163
|
{
|
91
|
-
bytes memory data = _store.getData(
|
164
|
+
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
92
165
|
|
93
166
|
if (data.length > 0) {
|
94
|
-
|
167
|
+
IComponents.ComponentInfo memory info = abi.decode(data, (IComponents.ComponentInfo));
|
95
168
|
return address(info.tokenHandler);
|
96
169
|
}
|
97
170
|
}
|
98
171
|
|
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
172
|
function getBundleInfo(NftId bundleNftId)
|
111
173
|
public
|
112
174
|
view
|
@@ -140,36 +202,48 @@ contract InstanceReader {
|
|
140
202
|
}
|
141
203
|
}
|
142
204
|
|
143
|
-
function
|
205
|
+
function getBalanceAmount(NftId targetNftId) external returns (Amount) {
|
206
|
+
return _store.getBalanceAmount(targetNftId);
|
207
|
+
}
|
208
|
+
|
209
|
+
function getLockedAmount(NftId targetNftId) external returns (Amount) {
|
210
|
+
return _store.getLockedAmount(targetNftId);
|
211
|
+
}
|
212
|
+
|
213
|
+
function getFeeAmount(NftId targetNftId) external returns (Amount) {
|
214
|
+
return _store.getFeeAmount(targetNftId);
|
215
|
+
}
|
216
|
+
|
217
|
+
function getComponentInfo(NftId componentNftId)
|
144
218
|
public
|
145
219
|
view
|
146
|
-
returns (
|
220
|
+
returns (IComponents.ComponentInfo memory info)
|
147
221
|
{
|
148
|
-
bytes memory data = _store.getData(
|
222
|
+
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
149
223
|
if (data.length > 0) {
|
150
|
-
return abi.decode(data, (
|
224
|
+
return abi.decode(data, (IComponents.ComponentInfo));
|
151
225
|
}
|
152
226
|
}
|
153
227
|
|
154
|
-
function
|
228
|
+
function getProductInfo(NftId productNftId)
|
155
229
|
public
|
156
230
|
view
|
157
|
-
returns (
|
231
|
+
returns (IComponents.ProductInfo memory info)
|
158
232
|
{
|
159
|
-
bytes memory data = _store.getData(
|
233
|
+
bytes memory data = _store.getData(toProductKey(productNftId));
|
160
234
|
if (data.length > 0) {
|
161
|
-
return abi.decode(data, (
|
235
|
+
return abi.decode(data, (IComponents.ProductInfo));
|
162
236
|
}
|
163
237
|
}
|
164
238
|
|
165
|
-
function
|
239
|
+
function getPoolInfo(NftId poolNftId)
|
166
240
|
public
|
167
241
|
view
|
168
|
-
returns (
|
242
|
+
returns (IComponents.PoolInfo memory info)
|
169
243
|
{
|
170
|
-
bytes memory data = _store.getData(
|
244
|
+
bytes memory data = _store.getData(toPoolKey(poolNftId));
|
171
245
|
if (data.length > 0) {
|
172
|
-
return abi.decode(data, (
|
246
|
+
return abi.decode(data, (IComponents.PoolInfo));
|
173
247
|
}
|
174
248
|
}
|
175
249
|
|
@@ -244,11 +318,6 @@ contract InstanceReader {
|
|
244
318
|
}
|
245
319
|
|
246
320
|
|
247
|
-
function toTreasuryKey(NftId productNftId) public pure returns (Key32) {
|
248
|
-
return productNftId.toKey32(TREASURY());
|
249
|
-
}
|
250
|
-
|
251
|
-
|
252
321
|
function toPolicyKey(NftId policyNftId) public pure returns (Key32) {
|
253
322
|
return policyNftId.toKey32(POLICY());
|
254
323
|
}
|
@@ -258,14 +327,18 @@ contract InstanceReader {
|
|
258
327
|
return distributorNftId.toKey32(DISTRIBUTOR());
|
259
328
|
}
|
260
329
|
|
261
|
-
function toDistributionKey(NftId distributionNftId) public pure returns (Key32) {
|
262
|
-
return distributionNftId.toKey32(DISTRIBUTION());
|
263
|
-
}
|
264
|
-
|
265
330
|
function toBundleKey(NftId poolNftId) public pure returns (Key32) {
|
266
331
|
return poolNftId.toKey32(BUNDLE());
|
267
332
|
}
|
268
333
|
|
334
|
+
function toComponentKey(NftId componentNftId) public pure returns (Key32) {
|
335
|
+
return componentNftId.toKey32(COMPONENT());
|
336
|
+
}
|
337
|
+
|
338
|
+
function toDistributionKey(NftId distributionNftId) public pure returns (Key32) {
|
339
|
+
return distributionNftId.toKey32(DISTRIBUTION());
|
340
|
+
}
|
341
|
+
|
269
342
|
function toPoolKey(NftId poolNftId) public pure returns (Key32) {
|
270
343
|
return poolNftId.toKey32(POOL());
|
271
344
|
}
|
@@ -290,4 +363,4 @@ contract InstanceReader {
|
|
290
363
|
function toInt(UFixed value) public pure returns (uint256) {
|
291
364
|
return UFixedLib.toInt(value);
|
292
365
|
}
|
293
|
-
}
|
366
|
+
}
|