@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,78 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
5
|
+
import {IService} from "../shared/IService.sol";
|
6
|
+
|
7
|
+
import {Amount} from "../type/Amount.sol";
|
8
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
9
|
+
import {NftId} from "../type/NftId.sol";
|
10
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
11
|
+
import {ReferralId} from "../type/Referral.sol";
|
12
|
+
import {RiskId} from "../type/RiskId.sol";
|
13
|
+
import {Seconds} from "../type/Seconds.sol";
|
14
|
+
import {StateId} from "../type/StateId.sol";
|
15
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
16
|
+
import {UFixed} from "../type/UFixed.sol";
|
17
|
+
import {Fee} from "../type/Fee.sol";
|
18
|
+
|
19
|
+
interface IPolicyService is IService {
|
20
|
+
|
21
|
+
error ErrorPolicyServicePolicyProductMismatch(NftId applicationNftId, NftId expectedProductNftId, NftId actualProductNftId);
|
22
|
+
error ErrorPolicyServicePolicyStateNotApplied(NftId applicationNftId);
|
23
|
+
error ErrorPolicyServicePolicyStateNotCollateralizedOrApplied(NftId applicationNftId);
|
24
|
+
|
25
|
+
error ErrorPolicyServicePremiumHigherThanExpected(Amount premiumExpectedAmount, Amount premiumToBePaidAmount);
|
26
|
+
error ErrorPolicyServiceBalanceInsufficient(address policyOwner, uint256 premiumAmount, uint256 balance);
|
27
|
+
error ErrorPolicyServiceAllowanceInsufficient(address policyOwner, address tokenHandler, uint256 premiumAmount, uint256 allowance);
|
28
|
+
|
29
|
+
error ErrorIPolicyServiceInsufficientAllowance(address customer, address tokenHandlerAddress, uint256 amount);
|
30
|
+
error ErrorPolicyServicePremiumAlreadyPaid(NftId policyNftId, Amount premiumPaidAmount);
|
31
|
+
error ErrorIPolicyServicePolicyNotActivated(NftId policyNftId);
|
32
|
+
error ErrorIPolicyServicePolicyAlreadyClosed(NftId policyNftId);
|
33
|
+
error ErrorIPolicyServicePolicyNotActive(NftId policyNftId, StateId state);
|
34
|
+
error ErrorPolicyServicePremiumNotFullyPaid(NftId policyNftId, Amount premiumAmount, Amount premiumPaidAmount);
|
35
|
+
error ErrorIPolicyServiceOpenClaims(NftId policyNftId, uint16 openClaimsCount);
|
36
|
+
error ErrorIPolicyServicePolicyHasNotExpired(NftId policyNftId, Timestamp expiredAt);
|
37
|
+
|
38
|
+
error ErrorPolicyServicePremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount recalculatedPremiumAmount);
|
39
|
+
error ErrorPolicyServiceTransferredPremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount transferredPremiumAmount);
|
40
|
+
|
41
|
+
/// @dev collateralizes the policy represented by {policyNftId}
|
42
|
+
/// sets the policy state to collateralized
|
43
|
+
/// may set the policy state to activated and set the activation date
|
44
|
+
/// optionally collects premiums and activates the policy.
|
45
|
+
/// - premium payment is only attempted if requirePremiumPayment is set to true
|
46
|
+
/// - activation is only done if activateAt is a non-zero timestamp
|
47
|
+
/// an application can only be collateralized in applied state
|
48
|
+
/// only the related product may collateralize an application
|
49
|
+
function collateralize(
|
50
|
+
NftId policyNftId,
|
51
|
+
bool requirePremiumPayment,
|
52
|
+
Timestamp activateAt
|
53
|
+
) external;
|
54
|
+
|
55
|
+
/// @dev declines an application represented by {policyNftId}
|
56
|
+
/// an application can only be declined in applied state
|
57
|
+
/// only the related product may decline an application
|
58
|
+
function decline(NftId policyNftId) external;
|
59
|
+
|
60
|
+
/// @dev collects the premium token for the specified policy
|
61
|
+
function collectPremium(NftId policyNftId, Timestamp activateAt) external;
|
62
|
+
|
63
|
+
/// @dev activates the specified policy and sets the activation date in the policy metadata
|
64
|
+
/// to activate a policy it needs to be in underwritten state
|
65
|
+
function activate(NftId policyNftId, Timestamp activateAt) external;
|
66
|
+
|
67
|
+
/// @dev expires the specified policy and sets the expiry date in the policy metadata
|
68
|
+
/// to expire a policy it must be in active state, policies may be expired even when the predefined expiry date is still in the future
|
69
|
+
/// a policy can only be closed when it has been expired. in addition, it must not have any open claims
|
70
|
+
/// this function can only be called by a product. the policy needs to match with the calling product
|
71
|
+
function expire(NftId policyNftId) external;
|
72
|
+
|
73
|
+
/// @dev closes the specified policy and sets the closed data in the policy metadata
|
74
|
+
/// a policy can only be closed when it has been expired. in addition, it must not have any open claims
|
75
|
+
/// this function can only be called by a product. the policy needs to match with the calling product
|
76
|
+
function close(NftId policyNftId) external;
|
77
|
+
|
78
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {Seconds} from "../type/Seconds.sol";
|
5
|
+
import {NftId} from "../type/NftId.sol";
|
6
|
+
import {ReferralId} from "../type/Referral.sol";
|
7
|
+
import {RiskId} from "../type/RiskId.sol";
|
8
|
+
import {Amount} from "../type/Amount.sol";
|
9
|
+
|
10
|
+
import {IService} from "./IApplicationService.sol";
|
11
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
12
|
+
|
13
|
+
interface IPricingService is IService
|
14
|
+
{
|
15
|
+
|
16
|
+
error ErrorPricingServiceTargetWalletAmountsMismatch();
|
17
|
+
error ErrorIPricingServiceBundlePoolMismatch(NftId bundleNftId, NftId bundlePoolNftId, NftId poolNftId);
|
18
|
+
error ErrorIPricingServiceFeeCalculationMismatch(
|
19
|
+
uint256 distributionFeeFixAmount,
|
20
|
+
uint256 distributionFeeVarAmount,
|
21
|
+
uint256 distributionOwnerFeeFixAmount,
|
22
|
+
uint256 distributionOwnerFeeVarAmount,
|
23
|
+
uint256 commissionAmount,
|
24
|
+
uint256 discountAmount
|
25
|
+
);
|
26
|
+
|
27
|
+
function calculatePremium(
|
28
|
+
NftId productNftId,
|
29
|
+
RiskId riskId,
|
30
|
+
Amount sumInsuredAmount,
|
31
|
+
Seconds lifetime,
|
32
|
+
bytes memory applicationData,
|
33
|
+
NftId bundleNftId,
|
34
|
+
ReferralId referralId
|
35
|
+
)
|
36
|
+
external
|
37
|
+
view
|
38
|
+
returns (IPolicy.Premium memory premium);
|
39
|
+
}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount} from "../type/Amount.sol";
|
5
|
+
import {Fee} from "../type/Fee.sol";
|
6
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
7
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
8
|
+
import {NftId} from "../type/NftId.sol";
|
9
|
+
import {ReferralId} from "../type/Referral.sol";
|
10
|
+
import {RiskId} from "../type/RiskId.sol";
|
11
|
+
import {Seconds} from "../type/Seconds.sol";
|
12
|
+
|
13
|
+
interface IProductComponent is IInstanceLinkedComponent {
|
14
|
+
|
15
|
+
function setFees(
|
16
|
+
Fee memory productFee,
|
17
|
+
Fee memory processingFee
|
18
|
+
) external;
|
19
|
+
|
20
|
+
function calculatePremium(
|
21
|
+
Amount sumInsuredAmount,
|
22
|
+
RiskId riskId,
|
23
|
+
Seconds lifetime,
|
24
|
+
bytes memory applicationData,
|
25
|
+
NftId bundleNftId,
|
26
|
+
ReferralId referralId
|
27
|
+
) external view returns (Amount premiumAmount);
|
28
|
+
|
29
|
+
function calculateNetPremium(
|
30
|
+
Amount sumInsuredAmount,
|
31
|
+
RiskId riskId,
|
32
|
+
Seconds lifetime,
|
33
|
+
bytes memory applicationData
|
34
|
+
) external view returns (Amount netPremiumAmount);
|
35
|
+
|
36
|
+
|
37
|
+
/// @dev returns initial pool specific infos for this pool
|
38
|
+
function getInitialProductInfo() external view returns (IComponents.ProductInfo memory info);
|
39
|
+
|
40
|
+
function getPoolNftId() external view returns (NftId poolNftId);
|
41
|
+
function getDistributionNftId() external view returns (NftId distributionNftId);
|
42
|
+
}
|
@@ -0,0 +1,33 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
5
|
+
import {IService} from "../shared/IService.sol";
|
6
|
+
|
7
|
+
import {NftId} from "../type/NftId.sol";
|
8
|
+
import {ReferralId} from "../type/Referral.sol";
|
9
|
+
import {RiskId} from "../type/RiskId.sol";
|
10
|
+
import {StateId} from "../type/StateId.sol";
|
11
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
12
|
+
import {UFixed} from "../type/UFixed.sol";
|
13
|
+
import {Fee} from "../type/Fee.sol";
|
14
|
+
|
15
|
+
interface IProductService is IService {
|
16
|
+
|
17
|
+
function createRisk(
|
18
|
+
RiskId riskId,
|
19
|
+
bytes memory data
|
20
|
+
) external;
|
21
|
+
|
22
|
+
|
23
|
+
function updateRisk(
|
24
|
+
RiskId riskId,
|
25
|
+
bytes memory data
|
26
|
+
) external;
|
27
|
+
|
28
|
+
|
29
|
+
function updateRiskState(
|
30
|
+
RiskId riskId,
|
31
|
+
StateId newState
|
32
|
+
) external;
|
33
|
+
}
|
@@ -0,0 +1,473 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
5
|
+
import {Product} from "./Product.sol";
|
6
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
7
|
+
import {IDistributionComponent} from "../distribution/IDistributionComponent.sol";
|
8
|
+
import {IInstance} from "../instance/IInstance.sol";
|
9
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
10
|
+
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
11
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
12
|
+
import {IBundle} from "../instance/module/IBundle.sol";
|
13
|
+
|
14
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
15
|
+
|
16
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
17
|
+
import {ClaimId, ClaimIdLib} from "../type/ClaimId.sol";
|
18
|
+
import {Timestamp, TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
19
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
20
|
+
import {ObjectType, APPLICATION, COMPONENT, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../type/ObjectType.sol";
|
21
|
+
import {APPLIED, COLLATERALIZED, ACTIVE, KEEP_STATE, CLOSED, DECLINED, CONFIRMED} from "../type/StateId.sol";
|
22
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
23
|
+
import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
|
24
|
+
import {ReferralId} from "../type/Referral.sol";
|
25
|
+
import {StateId} from "../type/StateId.sol";
|
26
|
+
import {VersionPart} from "../type/Version.sol";
|
27
|
+
|
28
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
29
|
+
import {IApplicationService} from "./IApplicationService.sol";
|
30
|
+
import {IBundleService} from "../pool/IBundleService.sol";
|
31
|
+
import {IClaimService} from "./IClaimService.sol";
|
32
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
33
|
+
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
34
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
35
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
36
|
+
import {IPolicyService} from "./IPolicyService.sol";
|
37
|
+
import {IPoolService} from "../pool/IPoolService.sol";
|
38
|
+
import {IPricingService} from "./IPricingService.sol";
|
39
|
+
import {IService} from "../shared/IService.sol";
|
40
|
+
import {Service} from "../shared/Service.sol";
|
41
|
+
|
42
|
+
contract PolicyService is
|
43
|
+
ComponentVerifyingService,
|
44
|
+
IPolicyService
|
45
|
+
{
|
46
|
+
using NftIdLib for NftId;
|
47
|
+
using TimestampLib for Timestamp;
|
48
|
+
|
49
|
+
IApplicationService internal _applicationService;
|
50
|
+
IComponentService internal _componentService;
|
51
|
+
IBundleService internal _bundleService;
|
52
|
+
IClaimService internal _claimService;
|
53
|
+
IDistributionService internal _distributionService;
|
54
|
+
IPoolService internal _poolService;
|
55
|
+
IPricingService internal _pricingService;
|
56
|
+
|
57
|
+
event LogProductServiceSender(address sender);
|
58
|
+
|
59
|
+
function _initialize(
|
60
|
+
address owner,
|
61
|
+
bytes memory data
|
62
|
+
)
|
63
|
+
internal
|
64
|
+
virtual override
|
65
|
+
initializer
|
66
|
+
{
|
67
|
+
(
|
68
|
+
address registryAddress,,
|
69
|
+
//address managerAddress
|
70
|
+
address authority
|
71
|
+
) = abi.decode(data, (address, address, address));
|
72
|
+
|
73
|
+
initializeService(registryAddress, authority, owner);
|
74
|
+
|
75
|
+
VersionPart majorVersion = getVersion().toMajorPart();
|
76
|
+
_applicationService = IApplicationService(getRegistry().getServiceAddress(APPLICATION(), majorVersion));
|
77
|
+
_bundleService = IBundleService(getRegistry().getServiceAddress(BUNDLE(), majorVersion));
|
78
|
+
_componentService = IComponentService(getRegistry().getServiceAddress(COMPONENT(), majorVersion));
|
79
|
+
_claimService = IClaimService(getRegistry().getServiceAddress(CLAIM(), majorVersion));
|
80
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), majorVersion));
|
81
|
+
_distributionService = IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), majorVersion));
|
82
|
+
_pricingService = IPricingService(getRegistry().getServiceAddress(PRICE(), majorVersion));
|
83
|
+
|
84
|
+
registerInterface(type(IPolicyService).interfaceId);
|
85
|
+
}
|
86
|
+
|
87
|
+
|
88
|
+
function getDomain() public pure override returns(ObjectType) {
|
89
|
+
return POLICY();
|
90
|
+
}
|
91
|
+
|
92
|
+
|
93
|
+
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
94
|
+
IRegistry.ObjectInfo memory productInfo;
|
95
|
+
(, productInfo,) = _getAndVerifyActiveComponent(PRODUCT());
|
96
|
+
product = Product(productInfo.objectAddress);
|
97
|
+
}
|
98
|
+
|
99
|
+
|
100
|
+
function decline(
|
101
|
+
NftId policyNftId
|
102
|
+
)
|
103
|
+
external
|
104
|
+
override
|
105
|
+
{
|
106
|
+
revert();
|
107
|
+
}
|
108
|
+
|
109
|
+
event LogDebug(uint idx, string message);
|
110
|
+
|
111
|
+
/// @dev underwites application which includes the locking of the required collateral from the pool.
|
112
|
+
function collateralize(
|
113
|
+
NftId applicationNftId, // = policyNftId
|
114
|
+
bool requirePremiumPayment,
|
115
|
+
Timestamp activateAt
|
116
|
+
)
|
117
|
+
external
|
118
|
+
virtual override
|
119
|
+
{
|
120
|
+
// check caller is registered product
|
121
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
122
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
123
|
+
|
124
|
+
// check policy is in state applied
|
125
|
+
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
126
|
+
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
127
|
+
}
|
128
|
+
|
129
|
+
// check policy matches with calling product
|
130
|
+
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
131
|
+
if(applicationInfo.productNftId != productNftId) {
|
132
|
+
revert ErrorPolicyServicePolicyProductMismatch(
|
133
|
+
applicationNftId,
|
134
|
+
applicationInfo.productNftId,
|
135
|
+
productNftId);
|
136
|
+
}
|
137
|
+
|
138
|
+
StateId newPolicyState = COLLATERALIZED();
|
139
|
+
|
140
|
+
// actual collateralizaion
|
141
|
+
(
|
142
|
+
Amount localCollateralAmount,
|
143
|
+
Amount totalCollateralAmount
|
144
|
+
) = _poolService.lockCollateral(
|
145
|
+
instance,
|
146
|
+
productNftId,
|
147
|
+
applicationNftId,
|
148
|
+
applicationInfo.bundleNftId,
|
149
|
+
applicationInfo.sumInsuredAmount);
|
150
|
+
|
151
|
+
// optional activation of policy
|
152
|
+
if(activateAt > zeroTimestamp()) {
|
153
|
+
newPolicyState = ACTIVE();
|
154
|
+
applicationInfo.activatedAt = activateAt;
|
155
|
+
applicationInfo.expiredAt = activateAt.addSeconds(applicationInfo.lifetime);
|
156
|
+
}
|
157
|
+
|
158
|
+
// optional collection of premium
|
159
|
+
if(requirePremiumPayment) {
|
160
|
+
Amount premiumPaidAmount = _calculateAndCollectPremium(
|
161
|
+
instance,
|
162
|
+
applicationNftId,
|
163
|
+
applicationInfo);
|
164
|
+
|
165
|
+
applicationInfo.premiumPaidAmount = premiumPaidAmount;
|
166
|
+
}
|
167
|
+
|
168
|
+
// store updated policy info
|
169
|
+
instance.getInstanceStore().updatePolicy(
|
170
|
+
applicationNftId,
|
171
|
+
applicationInfo,
|
172
|
+
newPolicyState);
|
173
|
+
|
174
|
+
// TODO add calling pool contract if it needs to validate application
|
175
|
+
|
176
|
+
// TODO: add logging
|
177
|
+
}
|
178
|
+
|
179
|
+
|
180
|
+
function collectPremium(
|
181
|
+
NftId policyNftId,
|
182
|
+
Timestamp activateAt
|
183
|
+
)
|
184
|
+
external
|
185
|
+
virtual
|
186
|
+
{
|
187
|
+
// check caller is registered product
|
188
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
189
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
190
|
+
StateId stateId = instanceReader.getPolicyState(policyNftId);
|
191
|
+
|
192
|
+
// check policy is in state collateralized or active
|
193
|
+
if (!(stateId == COLLATERALIZED() || stateId == ACTIVE())) {
|
194
|
+
revert ErrorPolicyServicePolicyStateNotCollateralizedOrApplied(policyNftId);
|
195
|
+
}
|
196
|
+
|
197
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
198
|
+
|
199
|
+
// check if premium is already collected
|
200
|
+
if (policyInfo.premiumPaidAmount.gtz()) {
|
201
|
+
revert ErrorPolicyServicePremiumAlreadyPaid(policyNftId, policyInfo.premiumPaidAmount);
|
202
|
+
}
|
203
|
+
|
204
|
+
policyInfo.premiumPaidAmount = _calculateAndCollectPremium(
|
205
|
+
instance,
|
206
|
+
policyNftId,
|
207
|
+
policyInfo);
|
208
|
+
|
209
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
210
|
+
|
211
|
+
if(activateAt.gtz() && policyInfo.activatedAt.eqz()) {
|
212
|
+
activate(policyNftId, activateAt);
|
213
|
+
}
|
214
|
+
|
215
|
+
// TODO: add logging
|
216
|
+
}
|
217
|
+
|
218
|
+
function activate(NftId policyNftId, Timestamp activateAt) public override {
|
219
|
+
// check caller is registered product
|
220
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
221
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
222
|
+
|
223
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
224
|
+
|
225
|
+
require(
|
226
|
+
policyInfo.activatedAt.eqz(),
|
227
|
+
"ERROR:PRS-020:ALREADY_ACTIVATED");
|
228
|
+
|
229
|
+
policyInfo.activatedAt = activateAt;
|
230
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
231
|
+
|
232
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, ACTIVE());
|
233
|
+
|
234
|
+
// TODO: add logging
|
235
|
+
}
|
236
|
+
|
237
|
+
|
238
|
+
function expire(
|
239
|
+
NftId policyNftId
|
240
|
+
)
|
241
|
+
external
|
242
|
+
override
|
243
|
+
// solhint-disable-next-line no-empty-blocks
|
244
|
+
{
|
245
|
+
|
246
|
+
}
|
247
|
+
|
248
|
+
function close(
|
249
|
+
NftId policyNftId
|
250
|
+
)
|
251
|
+
external
|
252
|
+
override
|
253
|
+
{
|
254
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
255
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
256
|
+
|
257
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
258
|
+
|
259
|
+
if (policyInfo.activatedAt.eqz()) {
|
260
|
+
revert ErrorIPolicyServicePolicyNotActivated(policyNftId);
|
261
|
+
}
|
262
|
+
|
263
|
+
StateId state = instanceReader.getPolicyState(policyNftId);
|
264
|
+
if (state != ACTIVE()) {
|
265
|
+
revert ErrorIPolicyServicePolicyNotActive(policyNftId, state);
|
266
|
+
}
|
267
|
+
|
268
|
+
if (policyInfo.closedAt.gtz()) {
|
269
|
+
revert ErrorIPolicyServicePolicyAlreadyClosed(policyNftId);
|
270
|
+
}
|
271
|
+
|
272
|
+
// TODO consider to allow for underpaid premiums (with the effects of reducing max payouts accordingly)
|
273
|
+
if (!(policyInfo.premiumAmount == policyInfo.premiumPaidAmount)) {
|
274
|
+
revert ErrorPolicyServicePremiumNotFullyPaid(policyNftId, policyInfo.premiumAmount, policyInfo.premiumPaidAmount);
|
275
|
+
}
|
276
|
+
|
277
|
+
if (policyInfo.openClaimsCount > 0) {
|
278
|
+
revert ErrorIPolicyServiceOpenClaims(policyNftId, policyInfo.openClaimsCount);
|
279
|
+
}
|
280
|
+
|
281
|
+
policyInfo.closedAt = TimestampLib.blockTimestamp();
|
282
|
+
|
283
|
+
_poolService.releaseCollateral(
|
284
|
+
instance,
|
285
|
+
policyNftId,
|
286
|
+
policyInfo);
|
287
|
+
|
288
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, CLOSED());
|
289
|
+
}
|
290
|
+
|
291
|
+
|
292
|
+
function _calculateAndCollectPremium(
|
293
|
+
IInstance instance,
|
294
|
+
NftId applicationNftId,
|
295
|
+
IPolicy.PolicyInfo memory applicationInfo
|
296
|
+
)
|
297
|
+
internal
|
298
|
+
virtual
|
299
|
+
returns (
|
300
|
+
Amount premiumPaidAmount
|
301
|
+
)
|
302
|
+
{
|
303
|
+
NftId productNftId = applicationInfo.productNftId;
|
304
|
+
|
305
|
+
// calculate premium details
|
306
|
+
IPolicy.Premium memory premium = _pricingService.calculatePremium(
|
307
|
+
productNftId,
|
308
|
+
applicationInfo.riskId,
|
309
|
+
applicationInfo.sumInsuredAmount,
|
310
|
+
applicationInfo.lifetime,
|
311
|
+
applicationInfo.applicationData,
|
312
|
+
applicationInfo.bundleNftId,
|
313
|
+
applicationInfo.referralId);
|
314
|
+
|
315
|
+
|
316
|
+
// update financials and transfer premium tokens
|
317
|
+
premiumPaidAmount = _processAndCollect(
|
318
|
+
instance,
|
319
|
+
productNftId,
|
320
|
+
applicationNftId,
|
321
|
+
applicationInfo.premiumAmount,
|
322
|
+
applicationInfo.bundleNftId,
|
323
|
+
applicationInfo.referralId,
|
324
|
+
premium);
|
325
|
+
}
|
326
|
+
|
327
|
+
|
328
|
+
function _processAndCollect(
|
329
|
+
IInstance instance,
|
330
|
+
NftId productNftId,
|
331
|
+
NftId policyNftId,
|
332
|
+
Amount premiumExpectedAmount,
|
333
|
+
NftId bundleNftId,
|
334
|
+
ReferralId referralId,
|
335
|
+
IPolicy.Premium memory premium
|
336
|
+
)
|
337
|
+
internal
|
338
|
+
virtual
|
339
|
+
returns (Amount premiumPaidAmount)
|
340
|
+
{
|
341
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
342
|
+
TokenHandler tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
343
|
+
address policyHolder = getRegistry().ownerOf(policyNftId);
|
344
|
+
premiumPaidAmount = AmountLib.toAmount(premium.premiumAmount);
|
345
|
+
|
346
|
+
_checkPremiumBalanceAndAllowance(
|
347
|
+
tokenHandler,
|
348
|
+
policyHolder,
|
349
|
+
premiumExpectedAmount,
|
350
|
+
premiumPaidAmount);
|
351
|
+
|
352
|
+
_processSaleAndTransferFunds(
|
353
|
+
instanceReader,
|
354
|
+
instance.getInstanceStore(),
|
355
|
+
tokenHandler,
|
356
|
+
policyHolder,
|
357
|
+
productNftId,
|
358
|
+
bundleNftId,
|
359
|
+
referralId,
|
360
|
+
premium);
|
361
|
+
}
|
362
|
+
|
363
|
+
|
364
|
+
function _checkPremiumBalanceAndAllowance(
|
365
|
+
TokenHandler tokenHandler,
|
366
|
+
address policyHolder,
|
367
|
+
Amount premiumExpectedAmount,
|
368
|
+
Amount premiumPaidAmount
|
369
|
+
)
|
370
|
+
internal
|
371
|
+
virtual
|
372
|
+
view
|
373
|
+
{
|
374
|
+
// TODO decide how to handle this properly
|
375
|
+
// not clear if this is the best way to handle this
|
376
|
+
if (premiumExpectedAmount < premiumPaidAmount) {
|
377
|
+
revert ErrorPolicyServicePremiumHigherThanExpected(premiumExpectedAmount, premiumPaidAmount);
|
378
|
+
}
|
379
|
+
|
380
|
+
uint256 premiumAmount = premiumPaidAmount.toInt();
|
381
|
+
uint256 balance = tokenHandler.getToken().balanceOf(policyHolder);
|
382
|
+
uint256 allowance = tokenHandler.getToken().allowance(policyHolder, address(tokenHandler));
|
383
|
+
|
384
|
+
if (balance < premiumAmount) {
|
385
|
+
revert ErrorPolicyServiceBalanceInsufficient(policyHolder, premiumAmount, balance);
|
386
|
+
}
|
387
|
+
|
388
|
+
if (allowance < premiumAmount) {
|
389
|
+
revert ErrorPolicyServiceAllowanceInsufficient(policyHolder, address(tokenHandler), premiumAmount, allowance);
|
390
|
+
}
|
391
|
+
}
|
392
|
+
|
393
|
+
|
394
|
+
function _processSaleAndTransferFunds(
|
395
|
+
InstanceReader instanceReader,
|
396
|
+
InstanceStore instanceStore,
|
397
|
+
TokenHandler tokenHandler,
|
398
|
+
address policyHolder,
|
399
|
+
NftId productNftId,
|
400
|
+
NftId bundleNftId,
|
401
|
+
ReferralId referralId,
|
402
|
+
IPolicy.Premium memory premium
|
403
|
+
)
|
404
|
+
internal
|
405
|
+
virtual
|
406
|
+
{
|
407
|
+
(
|
408
|
+
NftId distributionNftId,
|
409
|
+
address distributionWallet,
|
410
|
+
address poolWallet,
|
411
|
+
address productWallet
|
412
|
+
) = _getDistributionNftAndWallets(
|
413
|
+
instanceReader,
|
414
|
+
productNftId);
|
415
|
+
|
416
|
+
// update product fees, distribution and pool fees
|
417
|
+
_componentService.increaseProductFees(
|
418
|
+
instanceStore,
|
419
|
+
productNftId,
|
420
|
+
AmountLib.toAmount(premium.productFeeVarAmount + premium.productFeeFixAmount));
|
421
|
+
|
422
|
+
// update distribution fees and distributor commission and pool fees
|
423
|
+
_distributionService.processSale(
|
424
|
+
distributionNftId,
|
425
|
+
referralId,
|
426
|
+
premium);
|
427
|
+
|
428
|
+
// update pool and bundle fees
|
429
|
+
_poolService.processSale(
|
430
|
+
bundleNftId,
|
431
|
+
premium);
|
432
|
+
|
433
|
+
// transfer premium amounts to target wallets
|
434
|
+
tokenHandler.transfer(policyHolder, productWallet, premium.productFeeAmount);
|
435
|
+
tokenHandler.transfer(policyHolder, distributionWallet, premium.distributionFeeAndCommissionAmount);
|
436
|
+
tokenHandler.transfer(policyHolder, poolWallet, premium.poolPremiumAndFeeAmount);
|
437
|
+
}
|
438
|
+
|
439
|
+
|
440
|
+
function _getTokenHandlerAndProductWallet(
|
441
|
+
InstanceReader instanceReader,
|
442
|
+
NftId productNftId
|
443
|
+
)
|
444
|
+
internal
|
445
|
+
virtual
|
446
|
+
view
|
447
|
+
returns (
|
448
|
+
TokenHandler tokenHandler
|
449
|
+
)
|
450
|
+
{
|
451
|
+
tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
452
|
+
}
|
453
|
+
|
454
|
+
function _getDistributionNftAndWallets(
|
455
|
+
InstanceReader instanceReader,
|
456
|
+
NftId productNftId
|
457
|
+
)
|
458
|
+
internal
|
459
|
+
virtual
|
460
|
+
view returns (
|
461
|
+
NftId distributionNftId,
|
462
|
+
address distributionWallet,
|
463
|
+
address poolWallet,
|
464
|
+
address productWallet
|
465
|
+
)
|
466
|
+
{
|
467
|
+
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
468
|
+
distributionNftId = productInfo.distributionNftId;
|
469
|
+
distributionWallet = instanceReader.getComponentInfo(distributionNftId).wallet;
|
470
|
+
poolWallet = instanceReader.getComponentInfo(productInfo.poolNftId).wallet;
|
471
|
+
productWallet = instanceReader.getComponentInfo(productNftId).wallet;
|
472
|
+
}
|
473
|
+
}
|