@etherisc/gif-next 0.0.2-fd275d2-234 → 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 +28 -14
- 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/distribution/IDistributionComponent.sol/IDistributionComponent.json +969 -0
- 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 +73 -104
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +299 -1344
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +356 -181
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +453 -3116
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +612 -181
- 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 +485 -337
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +493 -400
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +330 -127
- 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 +71 -45
- 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/IProductService.sol/IProductService.json → pool/IBundleService.sol/IBundleService.json} +284 -360
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1148 -0
- 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/IComponentOwnerService.sol/IComponentOwnerService.json → product/IApplicationService.sol/IApplicationService.json} +231 -204
- 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/product/IPolicyService.sol/IPolicyService.json +701 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +244 -383
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +989 -0
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → product/IProductService.sol/IProductService.json} +140 -86
- 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/product/Product.sol/Product.json +1391 -0
- 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 +345 -121
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +368 -222
- 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 +434 -197
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +298 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +438 -333
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +324 -136
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +1112 -0
- 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 +449 -67
- 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/shared/Component.sol/Component.json +890 -0
- 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/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +196 -216
- 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/{instance/service/IDistributionService.sol/IDistributionService.json → shared/IComponent.sol/IComponent.json} +344 -165
- 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/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +699 -0
- 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 -34
- 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 +84 -178
- 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 +109 -29
- 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 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +126 -53
- 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 +185 -165
- 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/staking/IStakingService.sol/IStakingService.json +626 -0
- 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 +20 -20
- package/contracts/distribution/IDistributionComponent.sol +66 -0
- package/contracts/distribution/IDistributionService.sol +81 -0
- package/contracts/instance/BundleManager.sol +24 -50
- package/contracts/instance/IInstance.sol +57 -36
- package/contracts/instance/IInstanceService.sol +65 -14
- package/contracts/instance/Instance.sol +147 -373
- package/contracts/instance/InstanceAccessManager.sol +432 -177
- package/contracts/instance/InstanceAuthorizationsLib.sol +336 -0
- package/contracts/instance/InstanceReader.sol +136 -85
- package/contracts/instance/InstanceService.sol +304 -169
- package/contracts/instance/InstanceServiceManager.sol +12 -25
- 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} +17 -30
- package/contracts/instance/module/IAccess.sol +37 -21
- 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/Usdc.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 +14 -0
- package/contracts/registry/IRegistry.sol +65 -28
- package/contracts/registry/IRegistryService.sol +46 -28
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +353 -238
- package/contracts/registry/RegistryAccessManager.sol +167 -0
- package/contracts/registry/RegistryService.sol +165 -195
- package/contracts/registry/RegistryServiceManager.sol +34 -42
- package/contracts/registry/ReleaseManager.sol +530 -0
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +261 -53
- 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 +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +7 -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 -80
- package/contracts/shared/PolicyHolder.sol +101 -0
- package/contracts/shared/ProxyManager.sol +126 -25
- package/contracts/shared/Registerable.sol +26 -41
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +45 -23
- 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/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -618
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -280
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -249
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -787
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -729
- 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/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.json +0 -101
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1132
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -272
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- 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/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -716
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -444
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.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/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -971
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -460
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -1147
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -488
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- 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 -305
- 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 -600
- 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/BaseComponent.sol +0 -91
- package/contracts/components/Distribution.sol +0 -163
- package/contracts/components/IBaseComponent.sol +0 -25
- package/contracts/components/IDistributionComponent.sol +0 -44
- package/contracts/components/IPoolComponent.sol +0 -62
- package/contracts/components/IProductComponent.sol +0 -35
- package/contracts/components/Pool.sol +0 -247
- package/contracts/components/Product.sol +0 -289
- 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/AccessManagedSimple.sol +0 -115
- package/contracts/instance/AccessManagerSimple.sol +0 -692
- package/contracts/instance/IAccessManagerSimple.sol +0 -391
- package/contracts/instance/base/ComponentServiceBase.sol +0 -134
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- 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/ComponentOwnerService.sol +0 -317
- package/contracts/instance/service/DistributionService.sol +0 -88
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPoolService.sol +0 -43
- package/contracts/instance/service/IProductService.sol +0 -110
- package/contracts/instance/service/PoolService.sol +0 -206
- package/contracts/instance/service/PoolServiceManager.sol +0 -54
- package/contracts/instance/service/ProductService.sol +0 -561
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
- 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 -24
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- 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,67 +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
|
-
import {ITreasury} from "../instance/module/ITreasury.sol";
|
27
|
-
import {TimestampLib} from "../types/Timestamp.sol";
|
29
|
+
import {TimestampLib} from "../type/Timestamp.sol";
|
28
30
|
|
31
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
29
32
|
|
30
|
-
contract InstanceReader {
|
31
|
-
bool private _initialized;
|
32
33
|
|
33
|
-
|
34
|
-
NftId internal _instanceNftId;
|
35
|
-
IInstance internal _instance;
|
36
|
-
IKeyValueStore internal _store;
|
37
|
-
|
38
|
-
constructor(
|
39
|
-
address registry,
|
40
|
-
NftId instanceNftId
|
41
|
-
)
|
42
|
-
{
|
43
|
-
initialize(registry, instanceNftId);
|
44
|
-
}
|
34
|
+
contract InstanceReader {
|
45
35
|
|
46
|
-
|
47
|
-
|
36
|
+
error ErrorInstanceReaderAlreadyInitialized();
|
37
|
+
error ErrorInstanceReaderInstanceAddressZero();
|
48
38
|
|
49
|
-
|
50
|
-
address(registry) != address(0),
|
51
|
-
"ERROR:CRD-001:REGISTRY_ZERO");
|
39
|
+
bool private _initialized;
|
52
40
|
|
53
|
-
|
54
|
-
|
55
|
-
"ERROR:CRD-002:NFT_ID_ZERO");
|
41
|
+
IInstance internal _instance;
|
42
|
+
InstanceStore internal _store;
|
56
43
|
|
57
|
-
|
58
|
-
|
59
|
-
|
44
|
+
function initialize(address instance) public {
|
45
|
+
if(_initialized) {
|
46
|
+
revert ErrorInstanceReaderAlreadyInitialized();
|
47
|
+
}
|
60
48
|
|
61
|
-
|
62
|
-
|
63
|
-
|
49
|
+
if(instance == address(0)) {
|
50
|
+
revert ErrorInstanceReaderInstanceAddressZero();
|
51
|
+
}
|
64
52
|
|
65
|
-
_instance = IInstance(
|
66
|
-
_store =
|
53
|
+
_instance = IInstance(instance);
|
54
|
+
_store = _instance.getInstanceStore();
|
67
55
|
|
68
56
|
_initialized = true;
|
69
57
|
}
|
@@ -87,7 +75,74 @@ contract InstanceReader {
|
|
87
75
|
view
|
88
76
|
returns (StateId state)
|
89
77
|
{
|
90
|
-
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));
|
91
146
|
}
|
92
147
|
|
93
148
|
function getRiskInfo(RiskId riskId)
|
@@ -101,30 +156,19 @@ contract InstanceReader {
|
|
101
156
|
}
|
102
157
|
}
|
103
158
|
|
104
|
-
function getTokenHandler(NftId
|
159
|
+
function getTokenHandler(NftId componentNftId)
|
105
160
|
public
|
106
161
|
view
|
107
162
|
returns (address tokenHandler)
|
108
163
|
{
|
109
|
-
bytes memory data = _store.getData(
|
164
|
+
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
110
165
|
|
111
166
|
if (data.length > 0) {
|
112
|
-
|
167
|
+
IComponents.ComponentInfo memory info = abi.decode(data, (IComponents.ComponentInfo));
|
113
168
|
return address(info.tokenHandler);
|
114
169
|
}
|
115
170
|
}
|
116
171
|
|
117
|
-
function getTreasuryInfo(NftId productNftId)
|
118
|
-
public
|
119
|
-
view
|
120
|
-
returns (ITreasury.TreasuryInfo memory info)
|
121
|
-
{
|
122
|
-
bytes memory data = _store.getData(toTreasuryKey(productNftId));
|
123
|
-
if (data.length > 0) {
|
124
|
-
return abi.decode(data, (ITreasury.TreasuryInfo));
|
125
|
-
}
|
126
|
-
}
|
127
|
-
|
128
172
|
function getBundleInfo(NftId bundleNftId)
|
129
173
|
public
|
130
174
|
view
|
@@ -158,36 +202,48 @@ contract InstanceReader {
|
|
158
202
|
}
|
159
203
|
}
|
160
204
|
|
161
|
-
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)
|
162
218
|
public
|
163
219
|
view
|
164
|
-
returns (
|
220
|
+
returns (IComponents.ComponentInfo memory info)
|
165
221
|
{
|
166
|
-
bytes memory data = _store.getData(
|
222
|
+
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
167
223
|
if (data.length > 0) {
|
168
|
-
return abi.decode(data, (
|
224
|
+
return abi.decode(data, (IComponents.ComponentInfo));
|
169
225
|
}
|
170
226
|
}
|
171
227
|
|
172
|
-
function
|
228
|
+
function getProductInfo(NftId productNftId)
|
173
229
|
public
|
174
230
|
view
|
175
|
-
returns (
|
231
|
+
returns (IComponents.ProductInfo memory info)
|
176
232
|
{
|
177
|
-
bytes memory data = _store.getData(
|
233
|
+
bytes memory data = _store.getData(toProductKey(productNftId));
|
178
234
|
if (data.length > 0) {
|
179
|
-
return abi.decode(data, (
|
235
|
+
return abi.decode(data, (IComponents.ProductInfo));
|
180
236
|
}
|
181
237
|
}
|
182
238
|
|
183
|
-
function
|
239
|
+
function getPoolInfo(NftId poolNftId)
|
184
240
|
public
|
185
241
|
view
|
186
|
-
returns (
|
242
|
+
returns (IComponents.PoolInfo memory info)
|
187
243
|
{
|
188
|
-
bytes memory data = _store.getData(
|
244
|
+
bytes memory data = _store.getData(toPoolKey(poolNftId));
|
189
245
|
if (data.length > 0) {
|
190
|
-
return abi.decode(data, (
|
246
|
+
return abi.decode(data, (IComponents.PoolInfo));
|
191
247
|
}
|
192
248
|
}
|
193
249
|
|
@@ -262,11 +318,6 @@ contract InstanceReader {
|
|
262
318
|
}
|
263
319
|
|
264
320
|
|
265
|
-
function toTreasuryKey(NftId productNftId) public pure returns (Key32) {
|
266
|
-
return productNftId.toKey32(TREASURY());
|
267
|
-
}
|
268
|
-
|
269
|
-
|
270
321
|
function toPolicyKey(NftId policyNftId) public pure returns (Key32) {
|
271
322
|
return policyNftId.toKey32(POLICY());
|
272
323
|
}
|
@@ -276,14 +327,18 @@ contract InstanceReader {
|
|
276
327
|
return distributorNftId.toKey32(DISTRIBUTOR());
|
277
328
|
}
|
278
329
|
|
279
|
-
function toDistributionKey(NftId distributionNftId) public pure returns (Key32) {
|
280
|
-
return distributionNftId.toKey32(DISTRIBUTION());
|
281
|
-
}
|
282
|
-
|
283
330
|
function toBundleKey(NftId poolNftId) public pure returns (Key32) {
|
284
331
|
return poolNftId.toKey32(BUNDLE());
|
285
332
|
}
|
286
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
|
+
|
287
342
|
function toPoolKey(NftId poolNftId) public pure returns (Key32) {
|
288
343
|
return poolNftId.toKey32(POOL());
|
289
344
|
}
|
@@ -301,10 +356,6 @@ contract InstanceReader {
|
|
301
356
|
return _store;
|
302
357
|
}
|
303
358
|
|
304
|
-
function getInstanceNftId() external view returns (NftId nftId) {
|
305
|
-
return _instanceNftId;
|
306
|
-
}
|
307
|
-
|
308
359
|
function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
|
309
360
|
return UFixedLib.toUFixed(value, exp);
|
310
361
|
}
|
@@ -312,4 +363,4 @@ contract InstanceReader {
|
|
312
363
|
function toInt(UFixed value) public pure returns (uint256) {
|
313
364
|
return UFixedLib.toInt(value);
|
314
365
|
}
|
315
|
-
}
|
366
|
+
}
|