@etherisc/gif-next 0.0.2-c00cf5d-513 → 0.0.2-c0457ac-280
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/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +198 -177
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +130 -335
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +67 -96
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +83 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +35 -48
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +32 -101
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +65 -66
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +163 -10
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +81 -93
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +56 -40
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +84 -44
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +458 -331
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +268 -46
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +74 -43
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1095 -344
- 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 +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -71
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- 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/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +91 -264
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +56 -69
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +19 -51
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +145 -86
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +134 -133
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +242 -103
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +180 -376
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +42 -83
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +93 -167
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +56 -45
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +121 -211
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +64 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +20 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +20 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +94 -25
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +40 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +241 -107
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +13 -55
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +180 -297
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +54 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +163 -174
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +81 -54
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +337 -157
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +47 -230
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +34 -47
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +65 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +153 -1
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +294 -15
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1712 -103
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +198 -28
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +45 -42
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +321 -161
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -136
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +52 -20
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +52 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +100 -96
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +916 -55
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +539 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +76 -81
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +1 -11
- 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 +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +20 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -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 +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +33 -20
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +19 -32
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +17 -22
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +16 -16
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +40 -4
- 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/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +566 -54
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +657 -100
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +65 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +34 -34
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +96 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +114 -4
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +29 -53
- package/contracts/distribution/DistributionService.sol +61 -115
- package/contracts/distribution/IDistributionComponent.sol +5 -10
- package/contracts/distribution/IDistributionService.sol +2 -8
- package/contracts/instance/IInstance.sol +15 -7
- package/contracts/instance/IInstanceService.sol +35 -10
- package/contracts/instance/Instance.sol +63 -34
- package/contracts/instance/InstanceAdmin.sol +3 -2
- package/contracts/instance/InstanceAuthorizationsLib.sol +84 -27
- package/contracts/instance/InstanceReader.sol +64 -40
- package/contracts/instance/InstanceService.sol +185 -45
- package/contracts/instance/InstanceStore.sol +122 -64
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectManager.sol +1 -3
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +15 -4
- package/contracts/instance/module/IPolicy.sol +8 -2
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +278 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +79 -167
- package/contracts/pool/IBundleService.sol +4 -16
- package/contracts/pool/IPoolComponent.sol +4 -6
- package/contracts/pool/IPoolService.sol +45 -9
- package/contracts/pool/Pool.sol +39 -42
- package/contracts/pool/PoolService.sol +190 -142
- package/contracts/product/ApplicationService.sol +109 -42
- package/contracts/product/ClaimService.sol +18 -19
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +6 -8
- package/contracts/product/IPricingService.sol +3 -1
- package/contracts/product/IProductComponent.sol +7 -6
- package/contracts/product/IProductService.sol +1 -8
- package/contracts/product/PolicyService.sol +225 -128
- package/contracts/product/PricingService.sol +72 -48
- package/contracts/product/Product.sol +47 -49
- package/contracts/product/ProductService.sol +26 -114
- package/contracts/registry/ChainNft.sol +8 -1
- package/contracts/registry/IRegistry.sol +15 -4
- package/contracts/registry/IRegistryService.sol +10 -0
- package/contracts/registry/IServiceAuthorization.sol +35 -0
- package/contracts/registry/Registry.sol +164 -47
- package/contracts/registry/RegistryAdmin.sol +264 -72
- package/contracts/registry/RegistryService.sol +48 -14
- package/contracts/registry/RegistryServiceManager.sol +2 -9
- package/contracts/registry/ReleaseManager.sol +242 -177
- package/contracts/registry/ServiceAuthorization.sol +86 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +261 -64
- package/contracts/shared/AccessAdmin.sol +759 -0
- package/contracts/shared/AccessManagerCustom.sol +6 -1
- package/contracts/shared/AccessManagerExtended.sol +19 -7
- package/contracts/shared/Component.sol +139 -129
- package/contracts/shared/ComponentService.sol +563 -88
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessAdmin.sol +168 -0
- package/contracts/shared/IComponent.sol +17 -37
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +6 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/{instance/base → shared}/KeyValueStore.sol +30 -72
- package/contracts/{instance/base → shared}/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +3 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +2 -3
- package/contracts/shared/Registerable.sol +2 -2
- package/contracts/shared/Service.sol +32 -21
- package/contracts/shared/TokenHandler.sol +24 -1
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +98 -47
- package/contracts/staking/StakeManagerLib.sol +231 -0
- package/contracts/staking/Staking.sol +513 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +286 -44
- package/contracts/staking/StakingServiceManager.sol +7 -3
- package/contracts/staking/StakingStore.sol +613 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +20 -1
- package/contracts/type/Blocknumber.sol +20 -3
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/NftId.sol +14 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +142 -63
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +82 -20
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- 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 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- 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/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
@@ -1,5 +1,5 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IRegistry} from "../registry/IRegistry.sol";
|
5
5
|
import {Product} from "./Product.sol";
|
@@ -10,7 +10,6 @@ import {IPolicy} from "../instance/module/IPolicy.sol";
|
|
10
10
|
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
11
11
|
import {IRisk} from "../instance/module/IRisk.sol";
|
12
12
|
import {IBundle} from "../instance/module/IBundle.sol";
|
13
|
-
import {ISetup} from "../instance/module/ISetup.sol";
|
14
13
|
|
15
14
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
16
15
|
|
@@ -18,19 +17,22 @@ import {Amount, AmountLib} from "../type/Amount.sol";
|
|
18
17
|
import {ClaimId, ClaimIdLib} from "../type/ClaimId.sol";
|
19
18
|
import {Timestamp, TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
20
19
|
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
21
|
-
import {ObjectType, APPLICATION, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../type/ObjectType.sol";
|
20
|
+
import {ObjectType, APPLICATION, COMPONENT, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../type/ObjectType.sol";
|
22
21
|
import {APPLIED, COLLATERALIZED, ACTIVE, KEEP_STATE, CLOSED, DECLINED, CONFIRMED} from "../type/StateId.sol";
|
23
22
|
import {NftId, NftIdLib} from "../type/NftId.sol";
|
24
23
|
import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
|
24
|
+
import {ReferralId} from "../type/Referral.sol";
|
25
25
|
import {StateId} from "../type/StateId.sol";
|
26
26
|
import {VersionPart} from "../type/Version.sol";
|
27
27
|
|
28
|
-
import {
|
28
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
29
29
|
import {IApplicationService} from "./IApplicationService.sol";
|
30
30
|
import {IBundleService} from "../pool/IBundleService.sol";
|
31
31
|
import {IClaimService} from "./IClaimService.sol";
|
32
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
32
33
|
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
33
34
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
35
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
34
36
|
import {IPolicyService} from "./IPolicyService.sol";
|
35
37
|
import {IPoolService} from "../pool/IPoolService.sol";
|
36
38
|
import {IPricingService} from "./IPricingService.sol";
|
@@ -38,13 +40,14 @@ import {IService} from "../shared/IService.sol";
|
|
38
40
|
import {Service} from "../shared/Service.sol";
|
39
41
|
|
40
42
|
contract PolicyService is
|
41
|
-
|
43
|
+
ComponentVerifyingService,
|
42
44
|
IPolicyService
|
43
45
|
{
|
44
46
|
using NftIdLib for NftId;
|
45
47
|
using TimestampLib for Timestamp;
|
46
48
|
|
47
49
|
IApplicationService internal _applicationService;
|
50
|
+
IComponentService internal _componentService;
|
48
51
|
IBundleService internal _bundleService;
|
49
52
|
IClaimService internal _claimService;
|
50
53
|
IDistributionService internal _distributionService;
|
@@ -70,10 +73,11 @@ contract PolicyService is
|
|
70
73
|
initializeService(registryAddress, authority, owner);
|
71
74
|
|
72
75
|
VersionPart majorVersion = getVersion().toMajorPart();
|
73
|
-
|
76
|
+
_applicationService = IApplicationService(getRegistry().getServiceAddress(APPLICATION(), majorVersion));
|
74
77
|
_bundleService = IBundleService(getRegistry().getServiceAddress(BUNDLE(), majorVersion));
|
78
|
+
_componentService = IComponentService(getRegistry().getServiceAddress(COMPONENT(), majorVersion));
|
75
79
|
_claimService = IClaimService(getRegistry().getServiceAddress(CLAIM(), majorVersion));
|
76
|
-
|
80
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), majorVersion));
|
77
81
|
_distributionService = IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), majorVersion));
|
78
82
|
_pricingService = IPricingService(getRegistry().getServiceAddress(PRICE(), majorVersion));
|
79
83
|
|
@@ -81,14 +85,9 @@ contract PolicyService is
|
|
81
85
|
}
|
82
86
|
|
83
87
|
|
84
|
-
function getDomain() public pure override returns(ObjectType) {
|
85
|
-
return POLICY();
|
86
|
-
}
|
87
|
-
|
88
|
-
|
89
88
|
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
90
89
|
IRegistry.ObjectInfo memory productInfo;
|
91
|
-
(, productInfo,) =
|
90
|
+
(, productInfo,) = _getAndVerifyActiveComponent(PRODUCT());
|
92
91
|
product = Product(productInfo.objectAddress);
|
93
92
|
}
|
94
93
|
|
@@ -102,6 +101,7 @@ contract PolicyService is
|
|
102
101
|
revert();
|
103
102
|
}
|
104
103
|
|
104
|
+
event LogDebug(uint idx, string message);
|
105
105
|
|
106
106
|
/// @dev underwites application which includes the locking of the required collateral from the pool.
|
107
107
|
function collateralize(
|
@@ -113,9 +113,14 @@ contract PolicyService is
|
|
113
113
|
virtual override
|
114
114
|
{
|
115
115
|
// check caller is registered product
|
116
|
-
(NftId productNftId,, IInstance instance) =
|
116
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
117
117
|
InstanceReader instanceReader = instance.getInstanceReader();
|
118
118
|
|
119
|
+
// check policy is in state applied
|
120
|
+
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
121
|
+
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
122
|
+
}
|
123
|
+
|
119
124
|
// check policy matches with calling product
|
120
125
|
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
121
126
|
if(applicationInfo.productNftId != productNftId) {
|
@@ -124,14 +129,21 @@ contract PolicyService is
|
|
124
129
|
applicationInfo.productNftId,
|
125
130
|
productNftId);
|
126
131
|
}
|
127
|
-
|
128
|
-
// check policy is in state applied
|
129
|
-
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
130
|
-
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
131
|
-
}
|
132
132
|
|
133
133
|
StateId newPolicyState = COLLATERALIZED();
|
134
134
|
|
135
|
+
// actual collateralizaion
|
136
|
+
(
|
137
|
+
Amount localCollateralAmount,
|
138
|
+
Amount totalCollateralAmount
|
139
|
+
) = _poolService.lockCollateral(
|
140
|
+
instance,
|
141
|
+
address(instanceReader.getComponentInfo(productNftId).token),
|
142
|
+
productNftId,
|
143
|
+
applicationNftId,
|
144
|
+
applicationInfo.bundleNftId,
|
145
|
+
applicationInfo.sumInsuredAmount);
|
146
|
+
|
135
147
|
// optional activation of policy
|
136
148
|
if(activateAt > zeroTimestamp()) {
|
137
149
|
newPolicyState = ACTIVE();
|
@@ -139,51 +151,28 @@ contract PolicyService is
|
|
139
151
|
applicationInfo.expiredAt = activateAt.addSeconds(applicationInfo.lifetime);
|
140
152
|
}
|
141
153
|
|
142
|
-
// lock bundle collateral
|
143
|
-
Amount netPremiumAmount = AmountLib.zero(); // > 0 if immediate premium payment
|
144
|
-
|
145
154
|
// optional collection of premium
|
146
155
|
if(requirePremiumPayment) {
|
147
|
-
|
148
|
-
instance,
|
149
|
-
applicationNftId,
|
150
|
-
applicationInfo
|
156
|
+
Amount premiumPaidAmount = _calculateAndCollectPremium(
|
157
|
+
instance,
|
158
|
+
applicationNftId,
|
159
|
+
applicationInfo);
|
151
160
|
|
152
|
-
applicationInfo.premiumPaidAmount =
|
161
|
+
applicationInfo.premiumPaidAmount = premiumPaidAmount;
|
153
162
|
}
|
154
163
|
|
155
164
|
// store updated policy info
|
156
|
-
instance.getInstanceStore().updatePolicy(
|
157
|
-
|
158
|
-
// lock collateral and update pool and bundle book keeping
|
159
|
-
// pool retention level: fraction of sum insured that product will cover from pool funds directly
|
160
|
-
// eg retention level 30%, payouts up to 30% of the sum insured will be made from the product's pool directly
|
161
|
-
// for the remaining 70% the pool owns a policy that will cover claims that exceed the 30% of the sum insured
|
162
|
-
// might also call pool component (for isVerifyingApplications pools)
|
163
|
-
_poolService.lockCollateral(
|
164
|
-
instance,
|
165
|
-
productNftId,
|
165
|
+
instance.getInstanceStore().updatePolicy(
|
166
166
|
applicationNftId,
|
167
|
-
applicationInfo,
|
168
|
-
|
167
|
+
applicationInfo,
|
168
|
+
newPolicyState);
|
169
|
+
|
170
|
+
// TODO add calling pool contract if it needs to validate application
|
169
171
|
|
170
172
|
// TODO: add logging
|
171
173
|
}
|
172
174
|
|
173
175
|
|
174
|
-
function calculateRequiredCollateral(
|
175
|
-
UFixed collateralizationLevel,
|
176
|
-
Amount sumInsuredAmount
|
177
|
-
)
|
178
|
-
public
|
179
|
-
pure
|
180
|
-
virtual
|
181
|
-
returns(Amount collateralAmount)
|
182
|
-
{
|
183
|
-
UFixed collateralUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
|
184
|
-
return AmountLib.toAmount(collateralUFixed.toInt());
|
185
|
-
}
|
186
|
-
|
187
176
|
function collectPremium(
|
188
177
|
NftId policyNftId,
|
189
178
|
Timestamp activateAt
|
@@ -192,24 +181,27 @@ contract PolicyService is
|
|
192
181
|
virtual
|
193
182
|
{
|
194
183
|
// check caller is registered product
|
195
|
-
(
|
184
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
196
185
|
InstanceReader instanceReader = instance.getInstanceReader();
|
197
|
-
|
186
|
+
StateId stateId = instanceReader.getPolicyState(policyNftId);
|
198
187
|
|
199
|
-
|
200
|
-
|
188
|
+
// check policy is in state collateralized or active
|
189
|
+
if (!(stateId == COLLATERALIZED() || stateId == ACTIVE())) {
|
190
|
+
revert ErrorPolicyServicePolicyStateNotCollateralizedOrApplied(policyNftId);
|
201
191
|
}
|
202
192
|
|
203
|
-
|
193
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
204
194
|
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
195
|
+
// check if premium is already collected
|
196
|
+
if (policyInfo.premiumPaidAmount.gtz()) {
|
197
|
+
revert ErrorPolicyServicePremiumAlreadyPaid(policyNftId, policyInfo.premiumPaidAmount);
|
198
|
+
}
|
209
199
|
|
210
|
-
policyInfo.premiumPaidAmount =
|
200
|
+
policyInfo.premiumPaidAmount = _calculateAndCollectPremium(
|
201
|
+
instance,
|
202
|
+
policyNftId,
|
203
|
+
policyInfo);
|
211
204
|
|
212
|
-
_bundleService.increaseBalance(instance, policyInfo.bundleNftId, netPremiumAmount);
|
213
205
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
214
206
|
|
215
207
|
if(activateAt.gtz() && policyInfo.activatedAt.eqz()) {
|
@@ -221,7 +213,7 @@ contract PolicyService is
|
|
221
213
|
|
222
214
|
function activate(NftId policyNftId, Timestamp activateAt) public override {
|
223
215
|
// check caller is registered product
|
224
|
-
(,, IInstance instance) =
|
216
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
225
217
|
InstanceReader instanceReader = instance.getInstanceReader();
|
226
218
|
|
227
219
|
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
@@ -255,7 +247,7 @@ contract PolicyService is
|
|
255
247
|
external
|
256
248
|
override
|
257
249
|
{
|
258
|
-
(,, IInstance instance) =
|
250
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
259
251
|
InstanceReader instanceReader = instance.getInstanceReader();
|
260
252
|
|
261
253
|
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
@@ -286,6 +278,7 @@ contract PolicyService is
|
|
286
278
|
|
287
279
|
_poolService.releaseCollateral(
|
288
280
|
instance,
|
281
|
+
address(instanceReader.getComponentInfo(policyInfo.productNftId).token),
|
289
282
|
policyNftId,
|
290
283
|
policyInfo);
|
291
284
|
|
@@ -293,86 +286,190 @@ contract PolicyService is
|
|
293
286
|
}
|
294
287
|
|
295
288
|
|
296
|
-
function
|
289
|
+
function _calculateAndCollectPremium(
|
297
290
|
IInstance instance,
|
298
|
-
NftId
|
299
|
-
|
291
|
+
NftId applicationNftId,
|
292
|
+
IPolicy.PolicyInfo memory applicationInfo
|
300
293
|
)
|
301
294
|
internal
|
302
|
-
|
295
|
+
virtual
|
296
|
+
returns (
|
297
|
+
Amount premiumPaidAmount
|
298
|
+
)
|
303
299
|
{
|
304
|
-
|
305
|
-
if(premiumExpectedAmount.eqz()) {
|
306
|
-
return AmountLib.zero();
|
307
|
-
}
|
300
|
+
NftId productNftId = applicationInfo.productNftId;
|
308
301
|
|
309
|
-
|
310
|
-
IPolicy.PolicyInfo memory policyInfo = instance.getInstanceReader().getPolicyInfo(policyNftId);
|
302
|
+
// calculate premium details
|
311
303
|
IPolicy.Premium memory premium = _pricingService.calculatePremium(
|
312
304
|
productNftId,
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
);
|
320
|
-
|
321
|
-
if (premium.premiumAmount != premiumExpectedAmount.toInt()) {
|
322
|
-
revert ErrorPolicyServicePremiumMismatch(
|
323
|
-
policyNftId,
|
324
|
-
premiumExpectedAmount,
|
325
|
-
AmountLib.toAmount(premium.premiumAmount));
|
326
|
-
}
|
305
|
+
applicationInfo.riskId,
|
306
|
+
applicationInfo.sumInsuredAmount,
|
307
|
+
applicationInfo.lifetime,
|
308
|
+
applicationInfo.applicationData,
|
309
|
+
applicationInfo.bundleNftId,
|
310
|
+
applicationInfo.referralId);
|
327
311
|
|
328
|
-
address policyOwner = getRegistry().ownerOf(policyNftId);
|
329
|
-
ISetup.ProductSetupInfo memory productSetupInfo = instance.getInstanceReader().getProductSetupInfo(productNftId);
|
330
|
-
TokenHandler tokenHandler = productSetupInfo.tokenHandler;
|
331
|
-
if (tokenHandler.getToken().allowance(policyOwner, address(tokenHandler)) < premium.premiumAmount) {
|
332
|
-
revert ErrorIPolicyServiceInsufficientAllowance(policyOwner, address(tokenHandler), premium.premiumAmount);
|
333
|
-
}
|
334
312
|
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
313
|
+
// update financials and transfer premium tokens
|
314
|
+
premiumPaidAmount = _processAndCollect(
|
315
|
+
instance,
|
316
|
+
productNftId,
|
317
|
+
applicationNftId,
|
318
|
+
applicationInfo.premiumAmount,
|
319
|
+
applicationInfo.bundleNftId,
|
320
|
+
applicationInfo.referralId,
|
321
|
+
premium);
|
322
|
+
}
|
323
|
+
|
324
|
+
|
325
|
+
function _processAndCollect(
|
326
|
+
IInstance instance,
|
327
|
+
NftId productNftId,
|
328
|
+
NftId policyNftId,
|
329
|
+
Amount premiumExpectedAmount,
|
330
|
+
NftId bundleNftId,
|
331
|
+
ReferralId referralId,
|
332
|
+
IPolicy.Premium memory premium
|
333
|
+
)
|
334
|
+
internal
|
335
|
+
virtual
|
336
|
+
returns (Amount premiumPaidAmount)
|
337
|
+
{
|
338
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
339
|
+
TokenHandler tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
340
|
+
address policyHolder = getRegistry().ownerOf(policyNftId);
|
341
|
+
premiumPaidAmount = AmountLib.toAmount(premium.premiumAmount);
|
342
|
+
|
343
|
+
_checkPremiumBalanceAndAllowance(
|
344
|
+
tokenHandler,
|
345
|
+
policyHolder,
|
346
|
+
premiumExpectedAmount,
|
347
|
+
premiumPaidAmount);
|
348
|
+
|
349
|
+
_processSaleAndTransferFunds(
|
350
|
+
instanceReader,
|
351
|
+
instance.getInstanceStore(),
|
352
|
+
tokenHandler,
|
353
|
+
policyHolder,
|
354
|
+
productNftId,
|
355
|
+
bundleNftId,
|
356
|
+
referralId,
|
357
|
+
premium);
|
358
|
+
}
|
340
359
|
|
341
|
-
netPremiumAmount = AmountLib.toAmount(premium.netPremiumAmount);
|
342
360
|
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
361
|
+
function _checkPremiumBalanceAndAllowance(
|
362
|
+
TokenHandler tokenHandler,
|
363
|
+
address policyHolder,
|
364
|
+
Amount premiumExpectedAmount,
|
365
|
+
Amount premiumPaidAmount
|
366
|
+
)
|
367
|
+
internal
|
368
|
+
virtual
|
369
|
+
view
|
370
|
+
{
|
371
|
+
// TODO decide how to handle this properly
|
372
|
+
// not clear if this is the best way to handle this
|
373
|
+
if (premiumExpectedAmount < premiumPaidAmount) {
|
374
|
+
revert ErrorPolicyServicePremiumHigherThanExpected(premiumExpectedAmount, premiumPaidAmount);
|
347
375
|
}
|
348
376
|
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
377
|
+
uint256 premiumAmount = premiumPaidAmount.toInt();
|
378
|
+
uint256 balance = tokenHandler.getToken().balanceOf(policyHolder);
|
379
|
+
uint256 allowance = tokenHandler.getToken().allowance(policyHolder, address(tokenHandler));
|
380
|
+
|
381
|
+
if (balance < premiumAmount) {
|
382
|
+
revert ErrorPolicyServiceBalanceInsufficient(policyHolder, premiumAmount, balance);
|
355
383
|
}
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
address poolWallet = instance.getInstanceReader().getComponentInfo(productSetupInfo.poolNftId).wallet;
|
360
|
-
tokenHandler.transfer(policyOwner, poolWallet, poolAmountToTransfer);
|
361
|
-
_poolService.processSale(policyInfo.bundleNftId, premium, poolAmountToTransfer);
|
384
|
+
|
385
|
+
if (allowance < premiumAmount) {
|
386
|
+
revert ErrorPolicyServiceAllowanceInsufficient(policyHolder, address(tokenHandler), premiumAmount, allowance);
|
362
387
|
}
|
388
|
+
}
|
363
389
|
|
364
|
-
// validate total amount transferred
|
365
|
-
{
|
366
|
-
Amount totalTransferred = distributionFeeAmountToTransfer + poolAmountToTransfer + productFeeAmountToTransfer;
|
367
390
|
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
|
374
|
-
|
391
|
+
function _processSaleAndTransferFunds(
|
392
|
+
InstanceReader instanceReader,
|
393
|
+
InstanceStore instanceStore,
|
394
|
+
TokenHandler tokenHandler,
|
395
|
+
address policyHolder,
|
396
|
+
NftId productNftId,
|
397
|
+
NftId bundleNftId,
|
398
|
+
ReferralId referralId,
|
399
|
+
IPolicy.Premium memory premium
|
400
|
+
)
|
401
|
+
internal
|
402
|
+
virtual
|
403
|
+
{
|
404
|
+
(
|
405
|
+
NftId distributionNftId,
|
406
|
+
address distributionWallet,
|
407
|
+
address poolWallet,
|
408
|
+
address productWallet
|
409
|
+
) = _getDistributionNftAndWallets(
|
410
|
+
instanceReader,
|
411
|
+
productNftId);
|
412
|
+
|
413
|
+
// update product fees, distribution and pool fees
|
414
|
+
_componentService.increaseProductFees(
|
415
|
+
instanceStore,
|
416
|
+
productNftId,
|
417
|
+
AmountLib.toAmount(premium.productFeeVarAmount + premium.productFeeFixAmount));
|
418
|
+
|
419
|
+
// update distribution fees and distributor commission and pool fees
|
420
|
+
_distributionService.processSale(
|
421
|
+
distributionNftId,
|
422
|
+
referralId,
|
423
|
+
premium);
|
424
|
+
|
425
|
+
// update pool and bundle fees
|
426
|
+
_poolService.processSale(
|
427
|
+
bundleNftId,
|
428
|
+
premium);
|
429
|
+
|
430
|
+
// transfer premium amounts to target wallets
|
431
|
+
tokenHandler.transfer(policyHolder, productWallet, premium.productFeeAmount);
|
432
|
+
tokenHandler.transfer(policyHolder, distributionWallet, premium.distributionFeeAndCommissionAmount);
|
433
|
+
tokenHandler.transfer(policyHolder, poolWallet, premium.poolPremiumAndFeeAmount);
|
434
|
+
}
|
375
435
|
|
376
|
-
|
436
|
+
|
437
|
+
function _getTokenHandlerAndProductWallet(
|
438
|
+
InstanceReader instanceReader,
|
439
|
+
NftId productNftId
|
440
|
+
)
|
441
|
+
internal
|
442
|
+
virtual
|
443
|
+
view
|
444
|
+
returns (
|
445
|
+
TokenHandler tokenHandler
|
446
|
+
)
|
447
|
+
{
|
448
|
+
tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
449
|
+
}
|
450
|
+
|
451
|
+
function _getDistributionNftAndWallets(
|
452
|
+
InstanceReader instanceReader,
|
453
|
+
NftId productNftId
|
454
|
+
)
|
455
|
+
internal
|
456
|
+
virtual
|
457
|
+
view returns (
|
458
|
+
NftId distributionNftId,
|
459
|
+
address distributionWallet,
|
460
|
+
address poolWallet,
|
461
|
+
address productWallet
|
462
|
+
)
|
463
|
+
{
|
464
|
+
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
465
|
+
distributionNftId = productInfo.distributionNftId;
|
466
|
+
distributionWallet = instanceReader.getComponentInfo(distributionNftId).wallet;
|
467
|
+
poolWallet = instanceReader.getComponentInfo(productInfo.poolNftId).wallet;
|
468
|
+
productWallet = instanceReader.getComponentInfo(productNftId).wallet;
|
469
|
+
}
|
470
|
+
|
471
|
+
|
472
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
473
|
+
return POLICY();
|
377
474
|
}
|
378
475
|
}
|